glob及IO重定向

globbing: 文件名通配

    匹配模式:元字符

          *:匹配任意长度的任意字符

   pa* ,*pa* ,*pa,  *p*a*

   pa, paa, passwd

   ?:  匹配任意单个字符

   pa?

    pa,  paa  符合     passwd不符

   []:匹配指定范围内的任意单个字符

   有几种特殊格式; [a-z],[A-z],[a-z0-9]

   [[:upper:]]所有大写字母

   [[:lower:]]:所有小写字母

   [[:alpha:]]:所有字母

   [[:digit]]:所有数字

   [[:alnum:]]:所有字母和数字

   [[punct:]]:所有标点符号

   pa[0-9][0-9],z[0-9][0-9]

   [^]:匹配指定范围外的任意单个字符

   [^[:upper:]]:大写字母以为的任意字符

   [^0-9]

   [^[:alnum:]]

练习一:显示/var目录所有以1开头,以一个小写字母结尾,且中间出现一位任意字符的文件或目录

    ls -d /var/?[[:lower:]] 

练习二:显示/etc目录下,以任意一位数字开头,且以非数字结尾的文件或目录:

   ls -d /etc/[0-9]*[^0-9]

练习三:显示/etc目录下,以非字母开头,后面跟一个字母及其他任意长度任意字符符文件或目录

    ls -d/etc/[^a-z][a-z]*

练习四:复制/etc目录下,所有以m开头,以非数字结尾的文件或目录至/tmp/magedu.com 目录下;

   rm /etc/8eabc 

   cp -r /etc/m*[*0-9] /tmp/magedu.com 练习五:复制/usr/share/man  目录下,所有以man开头,后跟一个数字结尾的文件或目录至/tmp/man/目录下:

    cp -r /usr/share/man/man[0-9] /tmp/man/

练习6:复制/etc目录下,所有以.conf结尾,且以m,n,r,p开头的文件或目录至/tmp/conf.d/目录下;

cp -r /etc/[mnrp]*.conf /tmp/conf.d/

  

IO重定向及管道

          程序:指令+数据

                   程序:IO

可用输入的设备:文件

        键盘设备,文件系统上的常规文件,网卡等;

可输出设备:文件

       显示器,文件系统上的刹那贵文件,网卡等;

程序是数据流有三种:

输入的数据流:<—-标准输入(stdin),键盘

输出的数据流,——->标准输出    显示器

fd:file descriptor, 文件描述符

      标准输入:0

      标准输出:1

       错误输出:2

IO 重定向: 

       输出重定向:>

            特性:覆盖输出       危险!!

       输出重定向》 特性:追加输出

            # set -c  

  禁止覆盖输出重定向至已存在的文件

           # set  +c

  关闭上述特性

      错误输出流重定向:2>, 2>>

      合并正常输出流和错误输出流,(1)  &>,&>> 

(2)COMMAND >/path/to/somefile z>&1

     COMMAND >> /path/to/somefile 2>&

     特殊设备:/dev/null

     输入重定向:<

 tr [OPTION]….SET1 [SET2]

   把输入的数据当中的字符,凡是在SET1定义范围内出现的,通通对位转换为SET2出现的字符

    tr  abc  ABC        

用法1: tr SET1 SET2  < /PATH/FROM/SOMEFILE

用法2: tr -d SET1 < /PATH/FROM/SOMEFILE

    注意:不修改源文件

Here Document:<<

          cat << EOF

           cat > /PATH/TO/SOMEFILE << EOF

管道:连接程序,实现将前一个面临的输出直接定向后一个程序当作输入数据流

     COMMAND1  | COMMAND2 | COMMAND3|……

    tee命令:

     COMMAND | tee / PATH/TO/SOMEFILE 

练习1:把/etc/passwd文件的前6行的信息转换为大写字符后输出

    head -n  6 /etc/passwd | tr 'a-z' 'A-Z'

命令总结   trtee

原创文章,作者:shadow,如若转载,请注明出处:http://www.178linux.com/64441

(0)
shadowshadow
上一篇 2016-12-21
下一篇 2016-12-21

相关推荐

  • 文件的权限和访问控制列表

      在linux管理中,为了使不同的用户对文件有不同的操作权限。我们需要正确的修改文件的权限,一方面是为安全着想, 另一方面则是防止自己辛辛苦苦码出的东西被其它用户给误删。 1.如何修改文件的属主和属主:   前面用户和组管理的内容中,我们已经对文件的属主、属组问题做了说明。有时候我们需要对一些文件的属组和属组进行修改…

    Linux干货 2016-08-04
  • 第十二周课堂练习下

    6、在LAMP架构中,请分别以php编译成httpd模块形式和php以fpm工作为独立守护进程的方式来支持httpd,列出详细的过程 1.模块方式安装可见第三节 2.fpm独立守护进程安装 [root@LAMP setup]# tar -xf  php-5.6.23.tar.bz2  ##编译&nb…

    Linux干货 2017-01-03
  • Linux用户管理相关

    Q1列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 [root@radio_freshman ~]# who root     tty1         201…

    Linux干货 2016-11-13
  • 计算机网络基础

    计算机网络基础 分层的网络模型 网络发展到今天,规模很庞大,内容很复杂,不利于网络的管理和教学。网络分层可以:降低网络结构的复杂性、把各层的接口标准化、简化模块设计、确保技术的互操作性、加快发展速度以及简化教学过程。 OSI模型——国际标准:根据国际标准化组织( ISO,International Standards Orgnization)提案,计算机网络…

    Linux干货 2016-11-22
  • find命令使用练习

    1、  查找/var目录下属主为root,且属组为mail的所有文件   2、  查找/var目录下不属于root、lp、gdm的所有文件   3、  查找/var目录下最近一周内其内容修改过,同时属主不为root,也不是postfix的文件   4、  查找当前系统上没有属主或属组,且最…

    Linux干货 2016-08-15
  • 2班jackcui20160802作业

    1、每日课堂笔记总结 2、预习 3、每日课堂pdf练习 4、在/data/testdir里创建的新文件自动属于g1组,组g2的成员如:alice能对这些新文件有读写权限,组g3的成员如:tom只能对新文件有读权限,其它用户(不属于g1,g2,g3)不能访问这个文件夹。 [root@centos7 /]# groupadd g1 [root@centos7 /…

    Linux干货 2016-08-05