Linux:Day4(上) 文件管理、管道

时间:2023-03-09 14:53:07
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的,既然不用这种方法也可以实现,为什么还要用第一种方法?感觉这比第一种还简洁一点。 两种方法对比:
()第一种在输入的时候前面是有>这个符号,而第二种没有;
()第一种是用EOF结束,而第二种用ctrl+c结束;
()两种方法输错的时候都需要按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个字段。