zoukankan      html  css  js  c++  java
  • Linux:Day4(上) 文件管理、管道

        

    文件管理:cp、mv、rm

    复制命令:cp

      cp [OPTION]... [-T] SOURCE DEST
      cp [OPTION]... SOURCE... DIRECTORY
      cp [OPTION]... -t DIRECTORY SOURCE...

      (1) 源为单个文件

        【1】目标不存在:新建目标文件,将源文件内容复制到目标文件中。

        【2】目标存在:

            目标为文件:用源文件中的内容覆盖目标文件中的内容,无提示!如果想有提示,使用选项 -i。

            目标为目录:在目录新建文件名为源文件文件名的文件(如果存在此文件名,则覆盖),然后将源文件中的内容复制到新文件中。

      (2) 源为单个目录

        复制目录需要使用-r选项,不然报错!

        【1】目标不存在:创建指定目录,复制源目录中的所有文件至目标目录。      

        【2】目标存在:

            目标为文件:报错!

            目标为目录:在目标目录中创建同源目录名相同的目录,并将文件复制到此目录中

      (3) 源为多个文件,不论文件或目录:目标必须存在,且必须是目录。

        【1】目标不存在:报错!  cp: target `/tmp/test3' is not a directory

        【2】目标存在:

            目标为文件:报错!

            目标为目录:将源复制到目标目录,如果多个源文件中有目录,则要使用-r选项,不然目录复制不过去,但文件复制正常。

      常用选项:

        -i:交互式

        -r, -R:递归复制目录及内部的所有内容;

        -a:归档,相当于-dR   --preserve=all

          -d:--no dereference --preserve = links  不追踪符号链接,只保留链接

          --preserve [=ATTR_LIST]

            mode:权限

            ownership:属主属组

            timesamp:时间戳

            links:

            xattr:扩展属性

            context:上下文

            all:所有元数据

    移动文件:mv

      (1) 如果源为单个文件,行为和cp一样。

      (2) 如果源为单个目录:行为也和CP一样。

        目标不存在:和CP一样

        目录存在:

          目标为文件:报错!提示不能用目录改写非目录文件。

          目标为目录:和CP一样

      (3) 如果源为多个文件,无论文件或目录:

        目标不存在:和CP一样

        目标存在:

          目标为文件:和CP一样

          目村为目录:和CP一样

      总结:mv命令和CP是一样,唯一区别是mv不需要使用-r选项。 

      

    删除文件:rm,删除文件或目录

      删除的是目录:(1) 目录为空,可以删除。 (2) 目录不为空,要用-r或-R选项。

      删除的是文件:可以直接删除。

      

      

    文本编辑器:nano

      全屏幕的文件编辑器。

    bash的基础特性(2):

      1、命令别名(alias)

        (1)alias

          显示当前shell进程中所有可用的命令别名;

        (2)alias NAME="VALUE"  注:后面的值一定要加引号

           定义另名NAME,其相当于执行命令VALUE;      例:alias cdnet="cd /etc/sysconfig/network-scripts"

        注意:在命令行中定义的别名,仅对当前shell进程有效;如果想永久有效,要定义在配置文件中;

          仅对当前用户:~/.bashrc

          对所有用户有效:/etc/bashrc

          Note:编辑配置给出的新配置不会立即生效;

          bash进程重新读取配置文件:

            source /path/to/config_file

            或. /path/to/config_file

        撤消别名:unalias 

        Note:如果别名同原命令的名称,则如果要执行原命令,可使用 COMMAND

      2、glob (globbing)

        bash中用于实现文件名“通配”

          通配符:*, ?, [ ]

          (1) * :代表任意长度的任意字符

          (2) ? :任意单个字符   

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

            [a-z]:不区分字符大小写

            [A-Z]:大写字母  

          (4) [^ ]:取反

          

          专用字符集合:

            [:digit:]:任意数字,相当于0-9,并不是相当于[0-9]

            [:lower:]:任意小写字母

            [:upper:]:任意大写字母

            [:alpha:]:任意大小写字母

            [:alnum:]:任意数字和字母

            [:space:]:匹配空格

            [:punct:]:匹配标点符号

            [:graph:]:匹配图形

      练习:

        1、显示/var目录下所有以l开头,以一个小写字母结尾,且中间出现至少一位数字的文件或目录;

        2、显示/etc目录下,以任意一位数字开头,且以非数字结尾的文件或目录;

        3、显示/etc/目录下,以非字母开头,后面跟了一个字母及其它任意长度任意字符的文件或目录;

        4、复制/etc目录下,所有以m开头,以非数字结尾的文件或目录至/tmp/mageedu目录中;

        5、复制/etc目录下,所有以.d结尾的文件或目录至/tmp/magedu.com目录中;

        6、复制/etc目录下,所有以.conf结尾,且以m,n,r,p开头的文件或目录至/tmp/mageedu.com目录中;

      3、bash的快捷键

        Ctrl + l :清屏,相当于clear命令;

        Ctrl + a :跳转至命令开始处;

        Ctrl + e :跳转至命令结尾处;

        Ctrl + c :取消命令人执行;

        Ctrl + u :删除命令行首至光标所在处的所有内容;

        Ctrl + k :删除光标所在处至命令行尾部的所有内容;

        Ctrl + f:光标往后挪一个字符;

        Ctrl + b:光标往前挪一个字符;

      4、bash的I/O重定向及管道

        程序:指令+数据

          读入数据:Input

          输出数据:Output

        打开的文件都有一个fd:file descriptor(文件描述符)

        标准输入:keyoard,0

           标准输出:monitor,1

        标准错误输出:monitor,2

        

        I/O重定向:改变标准位置

        输出重定向:COMMAND > NEW_POS,COMMAND >> NEW_POS

          >:覆盖重定向,目标文件中的原有内容会被清除;(如果文件不存在则创建)

          >>:追加重定向,新内容会追加至目标文件尾部;(如果文件不存在则创建)

          # set -C:禁止将内容覆盖输出至已有文件中;文件不存在是可以执行成功的(创建一个新文件),文件存在即使是空的,也是不可以的。

            强制覆盖:>|

          # set +C:打开可覆盖功能。

          

          2>:覆盖重定向错误输出数据流;

          2>>:追加重定向错误输出数据流;

          标准输出和错误输出各自定向至不同位置:

            COMMAND > /path/to/file.out 2> /path/to/error.out

          合并标准输出和错误 输出为同一个数据流进行重定向:

            &>:覆盖重定向

            &>>:追加重定向

           另一种合并输出命令:(这种方式比上面那种更灵活)

            COMMAND > /path/to/file.out 2> &1

            COMMAND > /path/to/file.out 2>> &1

            COMMAND >> /path/to/file.out 2> &1

            COMMAND >> /path/to/file.out 2>> &1

        输入重定向:<    注:输入重定向只有这个符号,而且一般输入重定向只跟一个文件,如果想多个,要写脚本用循环实现。

          tr命令:转换或删除字符

          tr [OPTION]... SET1 [SET2]

            例:tr -d abc < /etc/fstab

              tr "a-z" "A-Z" < /etc/fstab

          注:重定向只能重定向文件,不能将另一个命令的输出结果重定向到另一个命令,如果需要将一个命令的输出结果送给另一个命令,要用下面的管道。(在LINUX中每一个命令都是一个程序,执行后就是一个进程,而进程之间是无法通信的,如果想通信,需要借助于管道。)

          例如下面这样是不可以的:

            [root@localhost tmp]# tr 'a-z' 'A-Z' < echo "$PATH"
            -bash: echo: No such file or directory

        HERE Documentation:<<    注:这个和输入重定向关系不大,是用来创建文档的。

          # cat << EOF

          # cat > /path/to/somefile << EOF

    关于此处的<<的使用一点疑问?
    
    此处的<<表示此处为文档,这样和cat使用可以追加指定内容到文件中,例如:
    
    [root@localhost tmp]# cat > /tmp/cat.out << EOF
    > this is new line?
    > yes,it is.
    > EOF
    [root@localhost tmp]# cat /tmp/cat.out 
    this is new line?
    yes,it is.
    
    可以看到,内容被写到了指定的文件中,这个没错,但是不用<<也可以实现:
    
    [root@localhost tmp]# cat >> /tmp/cat.out 
    this is another method!     
    is it OK?   
    ^C
    [root@localhost tmp]# cat /tmp/cat.out 
    this is new line?
    yes,it is.
    this is another method!
    is it OK?
    
    通过上面命令可以看出,使用第二种方法也是OK的,既然不用这种方法也可以实现,为什么还要用第一种方法?感觉这比第一种还简洁一点。
    
    两种方法对比:
    (1)第一种在输入的时候前面是有>这个符号,而第二种没有;
    (2)第一种是用EOF结束,而第二种用ctrl+c结束;
    (3)两种方法输错的时候都需要按shitf+backspace才能删除;
    
    可能由于现在学习还不够深入,对于两种内在的优劣还不明白,留下此问,待以后解决(2018年9月2日)

      管道:

        COMMAND1 | COMMAND2 | COMMAND3 | ...

        Note:最后一个命令会在当前shell进程的子shell进程中执行;

        tee命令:从标准输入读数据,输出至标准输出和指定文件。

          功能:tee可以放在任何你想截取内容的地方,然后将内容保存到文件中。(但tee的输出是覆盖输出,并不是追加输出)

          tee [OPTION]... [FILE]...

        示例:

          [root@localhost tmp]# echo "$PATH" | tee /tmp/path.out | tr 'a-z' 'A-Z'      不能用单引号
          /USR/LIB64/QT-3.3/BIN:/USR/LOCAL/SBIN:/USR/LOCAL/BIN:/SBIN:/BIN:/USR/SBIN:/USR/BIN:/ROOT/BIN
          [root@localhost tmp]# cat /tmp/path.out
          /usr/lib64/qt-3.3/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin
          [root@localhost tmp]# echo "$SHELL" | tee /tmp/path.out | tr 'a-z' 'A-Z'
          /BIN/BASH
          [root@localhost tmp]# cat /tmp/path.out
          /bin/bash

          

      练习:

        1、将/etc/passwd文件中的前5行内容转换为大写后保存至/tmp/passwd.out文件中;

        2、将登录至当前系统上用户信息中的后3行的信息转换为大写后保存至/tmp/who.out文件中;

    文本文件处理工具:wc, cut, sort, uniq

      wc命令:word count

        wc [OPTION]... [FILE]...

          -l:lines,只显示行数

          -w:words,只显示单词数

          -c:characters,只显示字节数

        示例:

        [root@localhost tmp]# wc /etc/passwd
        33 52 1576 /etc/passwd            -----分别是行数,单词数,字节数(注意:这里的单词仅指用空格分开的字符串,并不是真正的单词)

         

      cut命令:

        cut OPTION... [FILE]...

          -d DELIMITER:指明分隔符

          -f FILEDS:

            #:第#个字段

            #,#[,#]:离散的多个字段,例如:1,3,6

            #-#:,连续的多个字段,例如1-6

            混合使用:1-3,7

          --output-delimiter=STRING:指明输出时字段之间的分隔符

      sort命令:

        sort [OPTION]... [FILE]...

          -f:忽略字符大小写

          -r:逆序显示 

          -t DELIMITER:指明字段分隔符

          -k #:以指定字段为标准进行排序

          -n:以数值大小进行排序,默认以字符大小显示的。

          -u:uniq,排序后去重

          示例:      

            [root@localhost tmp]# sort -t: -k3 -n /etc/passwd | cut -d: -f3

      uniq命令:

        uniq [OPTION]... [INPUT [OUTPUT]]

          -c:显示每行重复出现的次数;

          -d:仅显示重复过的行;

          -u:仅显示不曾重复的行;

        Note:连续且完全相同方为重复;

        

    练习:以冒号分隔,取出/etc/passwd文件的第6行至第10行,并将这些信息按第3个字段的数值大小进行排序;最后仅显示各自的第1个字段。

  • 相关阅读:
    Jenkins的安全控制
    浅谈JNDI的使用
    hdu 4544 湫湫系列故事——消灭兔子
    如何在工作和实践中学习射频知识
    JSONObject 解析
    SharePoint 2010 WebPart Web部分 总的膏
    J2EE学习笔记
    C和指针 (pointers on C)——第十二章:利用结构和指针
    UVA
    EasyUI-DataGrid多线动态实现选择性合并
  • 原文地址:https://www.cnblogs.com/sq5288/p/9525235.html
Copyright © 2011-2022 走看看