本节课程目标

  • 了解shell中的通配符
  • 熟悉grep、cut、sort等小工具和shell中的通配符的使用

    一、文本处理工具

1. grep工具

grep是过滤工具;用于根据关键字进行行过滤

语法和选项

语法:

  1. # grep [选项] '关键字' 文件名

常见选项:

  1. OPTIONS:
  2. -i: 不区分大小写
  3. -v: 查找不包含指定内容的行,反向选择
  4. -w: 按单词搜索
  5. -o: 打印匹配关键字
  6. -c: 统计匹配到的行数
  7. -n: 显示行号
  8. -r: 逐层遍历目录查找
  9. -m: 匹配到多少条之后停止
  10. -A: 显示匹配行及后面多少行
  11. -B: 显示匹配行及前面多少行
  12. -C: 显示匹配
  13. -l:只列出匹配的文件名
  14. -L:列出不匹配的文件名
  15. -e: 使用正则匹配
  16. -E:使用扩展正则匹配
  17. ^key:以关键字开头
  18. key$:以关键字结尾
  19. ^$:匹配空行
  20. --color=auto :可以将找到的关键词部分加上颜色的显示

颜色显示(别名设置):

  1. 临时设置:
  2. # alias grep='grep --color=auto' //只针对当前终端和当前用户生效
  3. 永久设置:
  4. 1)全局(针对所有用户生效)
  5. vim /etc/bashrc
  6. alias grep='grep --color=auto'
  7. source /etc/bashrc
  8. 2)局部(针对具体的某个用户)
  9. vim ~/.bashrc
  10. alias grep='grep --color=auto'
  11. source ~/.bashrc

举例说明:

说明:不要直接使用/etc/passwd文件,将其拷贝到/tmp下做实验!

  1. grep -e 'mail|ftp' 多条件过滤 过滤包含maiil或者ftp的行
  2. grep -i root passwd 忽略大小写匹配包含root的行
  3. grep -w ftp passwd 精确匹配ftp单词
  4. grep -w hello passwd 精确匹配hello单词;自己添加包含hello的行到文件
  5. grep -wo ftp passwd 打印匹配到的关键字ftp
  6. grep -n root passwd 打印匹配到root关键字的行好
  7. grep -ni root passwd 忽略大小写匹配统计包含关键字root的行
  8. grep -nic root passwd 忽略大小写匹配统计包含关键字root的行数
  9. grep -i ^root passwd 忽略大小写匹配以root开头的行
  10. grep bash$ passwd 匹配以bash结尾的行
  11. grep -n ^$ passwd 匹配空行并打印行号
  12. grep ^# /etc/vsftpd/vsftpd.conf 匹配以#号开头的行
  13. grep -v ^# /etc/vsftpd/vsftpd.conf 匹配不以#号开头的行
  14. grep -A 5 mail passwd 匹配包含mail关键字及其后5
  15. grep -B 5 mail passwd 匹配包含mail关键字及其前5
  16. grep -C 5 mail passwd 匹配包含mail关键字及其前后5

文件从后往前快速查找

从文件尾部查找用特定的 tac 命令,然后用管道命令后接 grep 匹配指定命令,具体示例如下:
tac sout.log | grep 'api input'

匹配指定条数后停止

文件从后向前匹配的基础上,匹配指定的条数记录后停止可以如下命令:
tac sout.log | grep 'api input' -m 5
通过 grep 的命令参数 -m 后面指定匹配的条数值。
也可以在此基础上,若要显示匹配上下文,还需要加如下几个命令:

  • -C 后面跟上下文的行数,C 理解为 Context。
  • -A 后面跟匹配行数之后行数值,A 表示 After。
  • -B 后面跟匹配行数之前行数值,B 表示 Before。

tac sout.log | grep 'api input' -m 5 -A 2

2. cut工具

cut是截取工具,用于列的截取

语法和选项

语法:

  1. # cut 选项 文件名

常见选项:

  1. -c: 以字符为单位进行分割,截取
  2. -d: 自定义分隔符,默认为制表符\t
  3. -f: 与-d一起使用,指定截取哪个区域
  4. --output-delimiter= :指定输出分界符

举例说明:

  1. cut -d: -f1 1.txt 以:冒号分割,截取第1列内容
  2. cut -d: -f1,6,7 1.txt 以:冒号分割,截取第1,6,7列内容
  3. cut -c4 1.txt 截取文件中每行第4个字符
  4. cut -c1-4 1.txt 截取文件中每行的1-4个字符
  5. cut -c4-10 1.txt 截取文件中每行的4-10个字符
  6. cut -c5- 1.txt 从第5个字符开始截取后面所有字符

课堂练习:
用小工具列出你当系统的运行级别。5/3

  1. 如何查看系统运行级别
    • 命令runlevel
    • 文件/etc/inittab
  2. 如何过滤运行级别
  1. runlevel |cut -c3
  2. runlevel | cut -d ' ' -f2
  3. grep -v '^#' /etc/inittab | cut -d: -f2
  4. grep '^id' /etc/inittab |cut -d: -f2
  5. grep "initdefault:$" /etc/inittab | cut -c4
  6. grep -v ^# /etc/inittab |cut -c4
  7. grep 'id:' /etc/inittab |cut -d: -f2
  8. cut -d':' -f2 /etc/inittab |grep -v ^#
  9. cut -c4 /etc/inittab |tail -1
  10. cut -d: -f2 /etc/inittab |tail -1

3. sort工具

sort工具用于排序;它将文件的每一行作为一个单位,从首字符向后,依次按ASCII码值进行比较,最后将他们按升序输出。

语法和选项

  1. -u :去除重复行
  2. -r :降序排列,默认是升序
  3. -o : 将排序结果输出到文件中,类似重定向符号>
  4. -n :以数字排序,默认是按字符排序
  5. -t :分隔符
  6. -k :第N
  7. -b :忽略前导空格。
  8. -R :随机排序,每次运行的结果均不同

举例说明

  1. sort -n -t: -k3 1.txt 按照用户的uid进行升序排列
  2. sort -nr -t: -k3 1.txt 按照用户的uid进行降序排列
  3. sort -n 2.txt 按照数字排序
  4. sort -nu 2.txt 按照数字排序并且去重
  5. sort -nr 2.txt
  6. sort -nru 2.txt
  7. sort -nru 2.txt
  8. sort -n 2.txt -o 3.txt 按照数字排序并将结果重定向到文件
  9. sort -R 2.txt
  10. sort -u 2.txt
  11. sort -t' ' -kn,m -u 以空格为分隔符,按照第nm列的内容进行排序,并去重
  12. 要对某一列内容进行排序去重,n=m即可

4.uniq工具

uniq用于去除连续重复

  1. 常见选项:
  2. -c, --count 统计重复行次数prefix lines by the number of occurrences
  3. -d, --repeated 只显示重复行only print duplicate lines, one for each group
  4. -D print all duplicate lines
  5. --all-repeated[=METHOD] like -D, but allow separating groups
  6. with an empty line;
  7. METHOD={none(default),prepend,separate}
  8. -f, --skip-fields=N 不要比较前 N 个域
  9. --group[=METHOD] show all items, separating groups with an empty line;
  10. METHOD={separate(default),prepend,append,both}
  11. -i, --ignore-case 比较时忽略大小写差异
  12. -s, --skip-chars=N 不要比较起始 N 个字符
  13. -u, --unique 只输出不重复(内容唯一)的行求差集,找不同
  14. -z, --zero-terminated NUL 空字符而非换行符作为行尾分隔符
  15. -w, --check-chars=N 对每行第N 个字符以后的内容不作对照
  16. --help 显示此帮助信息并退出
  17. --version 显示版本信息并退出
  18. 举例说明:
  19. uniq 2.txt
  20. uniq -d 2.txt
  21. uniq -dc 2.txt

5.tee工具

tee工具是从标准输入读取并写入到标准输出和文件,即:双向覆盖重定向(屏幕输出|文本输入)

  1. 选项:
  2. -a 双向追加重定向 ,内容追加到给定的文件而非覆盖
  3. -i, --ignore-interrupts 忽略中断信号
  4. -p 对写入非管道的行为排查错误
  5. --output-error[=模式] 设置写入出错时的行为。见下面“模式”部分
  6. --help 显示此帮助信息并退出
  7. --version 显示版本信息并退出
  8. echo hello world
  9. echo hello world|tee file1
  10. cat file1
  11. echo 999|tee -a file1
  12. cat file1

6.diff工具

diff工具用于逐行比较文件的不同

注意:diff描述两个文件不同的方式是告诉我们怎样改变第一个文件之后与第二个文件匹配。

语法和选项

语法:

  1. diff [选项] 文件列表
  2. 用法:diff [选项]... 文件列表
  3. 逐行比较<各文件>。
  4. 长选项的必需参数也是相应短选项的必需参数。
  5. --normal 以正常的 diff 方式输出 (默认)
  6. -q, --brief 只有在文件不同时报告
  7. -s, --report-identical-files 当两个一样时仍然显示结果
  8. -c, -C NUM, --context[=NUM] 同时输出 NUM 行(默认为 3 行)的复制上下文内容
  9. -u, -U 数量, --unified[=数量] 输出 <数量>(默认为 3)行一致化上下文
  10. -e, --ed ed script 方式输出
  11. -n, --rcs RCS diff 格式输出
  12. -y, --side-by-side 以两栏的格式输出
  13. -W, --width=数量 每行显示最多 <数量>(默认 130)个字符
  14. --left-column 当有两行相同时只显示左边栏的一行
  15. --suppress-common-lines 当有两行相同时不显示
  16. -p, --show-c-function 显示每个变更位于哪个 C 函数中
  17. -F, --show-function-line=正则 显示匹配给定<正则>表达式的最近一行
  18. --label 标签 使用给定<标签>替代文件名和时间戳
  19. (可以重复)
  20. -t, --expand-tabs 将输出中的 tab 转换成空格
  21. -T, --initial-tab 每行先加上 tab 字符,使 tab 字符可以对齐
  22. --tabsize=数字 TAB 格的宽度,默认为 8 个打印列宽
  23. --suppress-blank-empty 在空的输出行之前去除空白或制表符
  24. -l, --paginate 将输出送至 pr 指令来分页
  25. -r, --recursive 连同所有子目录一起比较
  26. --no-dereference 不要跟随符号链接
  27. -N, --new-file 不存在的文件以空文件方式处理
  28. --unidirectional-new-file 若第一文件不存在,以空文件处理
  29. --ignore-file-name-case 忽略文件名大小写的区别
  30. --no-ignore-file-name-case 不忽略文件名大小写的区别
  31. -x, --exclude=模式 排除匹配 <模式> 的文件
  32. -X, --exclude-from=文件 排除所有匹配在<文件>中列出的模式的文件
  33. -S, --starting-file=文件 当比较目录時,由<文件>开始比较
  34. --from-file=文件1 将<文件1>和操作数中的所有文件/目录作比较;
  35. <文件1>可以是目录
  36. --to-file=文件2 将操作数中的所有文件/目录和<文件2>作比较;
  37. <文件2>可以是目录
  38. -i, --ignore-case 忽略文件内容大小写的区别
  39. -E, --ignore-tab-expansion 忽略由制表符宽度造成的差异
  40. -Z, --ignore-trailing-space 忽略每行末端的空格
  41. -b, --ignore-space-change 忽略由空格数不同造成的差异
  42. -w, --ignore-all-space 忽略所有空格
  43. -B, --ignore-blank-lines 忽略任何因空行而造成的差异
  44. -I, --ignore-matching-lines=正则 若某行完全匹配 <正则>,则忽略由该行造成的差异
  45. -a, --text 所有文件都以文本方式处理
  46. --strip-trailing-cr 去除输入内容每行末端的回车(CR)字符
  47. -D, --ifdef=名称 输出的内容以 ‘#ifdef <名称>’ 方式标明差异
  48. --GTYPE-group-format=GFMT GFMT 格式处理 GTYPE 输入行组
  49. --line-format=LFMT LFMT 格式处理每一行资料
  50. --LTYPE-line-format=LFMT LFMT 格式处理 LTYPE 输入的行
  51. -d, --minimal 尽可能找出最小的差异集
  52. --horizon-lines=数量 保持<数量>行的一致前后缀
  53. --speed-large-files 假设文件十分大而且文件中含有许多微小的差异
  54. --color[=何时] 给输出上色;“何时”可以是“never”(从不)、
  55. always”(总是)或“auto”(自动,默认)
  56. --palette=调色板 --color 选项启用时使用的颜色;<调色板>参数应当是
  57. 一个冒号分隔的列表以提供 terminfo capabilities 信息

常用选项:

选项 含义 备注
-b 不检查空格
-B 不检查空白行
-i 不检查大小写
-w 忽略所有的空格
—normal 正常格式显示(默认)
-c 上下文格式显示
-u 合并格式显示

举例说明:

  • 比较两个普通文件异同,文件准备:
  1. [root@MissHou ~]# cat file1
  2. aaaa
  3. 111
  4. hello world
  5. 222
  6. 333
  7. bbb
  8. [root@MissHou ~]#
  9. [root@MissHou ~]# cat file2
  10. aaa
  11. hello
  12. 111
  13. 222
  14. bbb
  15. 333
  16. world
  17. [root@MissHou ~]# diff -u file1 file2 >diff.log
  18. [root@MissHou ~]# rm -f file2
  19. # 备份file1 -> file1.orig 找回file2 -> file1
  20. [root@MissHou ~]# patch -b file1 diff.log

1)正常显示

  1. diff目的:file1如何改变才能和file2匹配
  2. [root@MissHou ~]# diff file1 file2
  3. 1c1,2 第一个文件的第1行需要改变(c=change)才能和第二个文件的第12行匹配
  4. < aaaa 小于号"<"表示左边文件(file1)文件内容
  5. --- ---表示分隔符
  6. > aaa 大于号">"表示右边文件(file2)文件内容
  7. > hello
  8. 3d3 第一个文件的第3行删除(d=delete)后才能和第二个文件的第3行匹配
  9. < hello world
  10. 5d4 第一个文件的第5行删除后才能和第二个文件的第4行匹配
  11. < 333
  12. 6a6,7 第一个文件的第6行增加(a=add)内容后才能和第二个文件的第67行匹配
  13. > 333 需要增加的内容在第二个文件里是333world
  14. > world

2)上下文格式显示

  1. [root@MissHou ~]# diff -c file1 file2
  2. 前两行主要列出需要比较的文件名和文件的时间戳;文件名前面的符号***表示file1,---表示file2
  3. *** file1 2019-04-16 16:26:05.748650262 +0800
  4. --- file2 2019-04-16 16:26:30.470646030 +0800
  5. *************** 我是分隔符
  6. *** 1,6 **** 以***开头表示file1文件,1,6表示16
  7. ! aaaa !表示该行需要修改才与第二个文件匹配
  8. 111
  9. - hello world -表示需要删除该行才与第二个文件匹配
  10. 222
  11. - 333 -表示需要删除该行才与第二个文件匹配
  12. bbb
  13. --- 1,7 ---- 以---开头表示file2文件,1,7表示17
  14. ! aaa 表示第一个文件需要修改才与第二个文件匹配
  15. ! hello 表示第一个文件需要修改才与第二个文件匹配
  16. 111
  17. 222
  18. bbb
  19. + 333 表示第一个文件需要加上该行才与第二个文件匹配
  20. + world 表示第一个文件需要加上该行才与第二个文件匹配

3)合并格式显示

  1. [root@MissHou ~]# diff -u file1 file2
  2. 前两行主要列出需要比较的文件名和文件的时间戳;文件名前面的符号---表示file1,+++表示file2
  3. --- file1 2019-04-16 16:26:05.748650262 +0800
  4. +++ file2 2019-04-16 16:26:30.470646030 +0800
  5. @@ -1,6 +1,7 @@
  6. -aaaa
  7. +aaa
  8. +hello
  9. 111
  10. -hello world
  11. 222
  12. -333
  13. bbb
  14. +333
  15. +world
  • 比较两个目录不同
  1. 默认情况下也会比较两个目录里相同文件的内容
  2. [root@MissHou tmp]# diff dir1 dir2
  3. diff dir1/file1 dir2/file1
  4. 0a1
  5. > hello
  6. Only in dir1: file3
  7. Only in dir2: test1
  8. 如果只需要比较两个目录里文件的不同,不需要进一步比较文件内容,需要加-q选项
  9. [root@MissHou tmp]# diff -q dir1 dir2
  10. Files dir1/file1 and dir2/file1 differ
  11. Only in dir1: file3
  12. Only in dir2: test1

其他小技巧:

有时候我们需要以一个文件为标准,去修改其他文件,并且修改的地方较多时,我们可以通过打补丁的方式完成。

  1. 1)先找出文件不同,然后输出到一个文件
  2. [root@MissHou ~]# diff -uN file1 file2 > file.patch
  3. -u:上下文模式
  4. -N:将不存在的文件当作空文件
  5. 2)将不同内容打补丁到文件
  6. [root@MissHou ~]# patch file1 file.patch
  7. patching file file1
  8. 3)测试验证
  9. [root@MissHou ~]# diff file1 file2
  10. [root@MissHou ~]#

7. paste工具

paste工具用于合并文件行

  1. 常用选项:
  2. -d:自定义间隔符,默认是tab
  3. -s:串行处理,非并行

8. tr工具

tr用于字符转换,替换和删除;主要用于删除文件中控制字符或进行字符转换

语法和选项

语法:

  1. 用法1:命令的执行结果交给tr处理,其中string1用于查询,string2用于转换处理
  2. commands|tr 'string1' 'string2'
  3. 用法2tr处理的内容来自文件,记住要使用"<"标准输入
  4. tr 'string1' 'string2' < filename
  5. 用法3:匹配string1进行相应操作,如删除操作
  6. tr [options] 'string1' < filename

常用选项:

  1. -c 用字符串1中字符集的补集替换此字符集,要求字符集为ASCII
  2. -d 删除字符串1中所有输入字符。
  3. -s 删除所有重复出现字符序列,只保留第一个;即将重复出现字符串压缩为一个字符串

常匹配字符串:

字符串 含义 备注
a-z
或[:lower:]
匹配所有小写字母 所有大小写和数字[a-zA-Z0-9]
A-Z
或[:upper:]
匹配所有大写字母
0-9
或[:digit:]
匹配所有数字
[:alnum:] 匹配所有字母和数字
[:alpha:] 匹配所有字母
[:blank:] 所有水平空白
[:punct:] 匹配所有标点符号
[:space:] 所有水平或垂直的空格
[:cntrl:] 所有控制字符 \f Ctrl-L 走行换页
\n Ctrl-J 换行
Ctrl-M 回车
\t Ctrl-I tab键

举例说明:

  1. [root@MissHou shell01]# cat 3.txt 自己创建该文件用于测试
  2. ROOT:x:0:0:root:/root:/bin/bash
  3. bin:x:1:1:bin:/bin:/sbin/nologin
  4. daemon:x:2:2:daemon:/sbin:/sbin/nologin
  5. adm:x:3:4:adm:/var/adm:/sbin/nologin
  6. lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
  7. sync:x:5:0:sync:/sbin:/bin/sync
  8. shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
  9. halt:x:7:0:halt:/sbin:/sbin/halt
  10. mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
  11. uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
  12. boss02:x:516:511::/home/boss02:/bin/bash
  13. vip:x:517:517::/home/vip:/bin/bash
  14. stu1:x:518:518::/home/stu1:/bin/bash
  15. mailnull:x:47:47::/var/spool/mqueue:/sbin/nologin
  16. smmsp:x:51:51::/var/spool/mqueue:/sbin/nologin
  17. aaaaaaaaaaaaaaaaaaaa
  18. bbbbbb111111122222222222233333333cccccccc
  19. hello world 888
  20. 666
  21. 777
  22. 999
  23. tr -d '[:/]' < 3.txt 删除文件中的:和/
  24. cat 3.txt |tr -d '[:/]' 删除文件中的:和/
  25. tr '[0-9]' '@' < 3.txt 将文件中的数字替换为@符号
  26. tr '[a-z]' '[A-Z]' < 3.txt 将文件中的小写字母替换成大写字母
  27. tr -s '[a-z]' < 3.txt 匹配小写字母并将重复的压缩为一个
  28. tr -s '[a-z0-9]' < 3.txt 匹配小写字母和数字并将重复的压缩为一个
  29. tr -d '[:digit:]' < 3.txt 删除文件中的数字
  30. tr -d '[:blank:]' < 3.txt 删除水平空白
  31. tr -d '[:space:]' < 3.txt 删除所有水平和垂直空白
  32. df | tr -s ' ' : | cut -d: -f1,3 把所有空格压缩成:,再按:分割取出第13

小试牛刀

  1. 使用小工具分别截取当前主机IP;截取NETMASK;截取广播地址;截取MAC地址
  1. ifconfig eth0|grep 'Bcast'|tr -d '[a-zA-Z ]'|cut -d: -f2,3,4
  2. 10.1.1.1:10.1.1.255:255.255.255.0
  3. ifconfig eth0|grep 'Bcast'|tr -d '[a-zA-Z ]'|cut -d: -f2,3,4|tr ':' '\n'
  4. 10.1.1.1
  5. 10.1.1.255
  6. 255.255.255.0
  7. ifconfig eth0|grep 'HWaddr'|cut -d: -f2-|cut -d' ' -f4
  8. 00:0C:29:25:AE:54
  9. ifconfig eth0|grep 'HW'|tr -s ' '|cut -d' ' -f5
  10. 00:0C:29:B4:9E:4E
  11. ifconfig eth1|grep Bcast|cut -d: -f2|cut -d' ' -f1
  12. ifconfig eth1|grep Bcast|cut -d: -f2|tr -d '[ a-zA-Z]'
  13. ifconfig eth1|grep Bcast|tr -d '[:a-zA-Z]'|tr ' ' '@'|tr -s '@'|tr '@' '\n'|grep -v ^$
  14. ifconfig eth0|grep 'Bcast'|tr -d [:alpha:]|tr '[ :]' '\n'|grep -v ^$
  15. ifconfig eth1|grep HWaddr|cut -d ' ' -f11
  16. ifconfig eth0|grep HWaddr|tr -s ' '|cut -d' ' -f5
  17. ifconfig eth1|grep HWaddr|tr -s ' '|cut -d' ' -f5
  18. ifconfig eth0|grep 'Bcast'|tr -d 'a-zA-Z:'|tr ' ' '\n'|grep -v '^$'
  1. 将系统中所有普通用户的用户名、密码和默认shell保存到一个文件中,要求用户名密码和默认shell之间用tab键分割
  1. grep 'bash$' passwd |grep -v 'root'|cut -d: -f1,2,7|tr ':' '\t' |tee abc.txt

9. wc计数器

语法和选项

语法:

  1. 语法:用法:wc [选项]... [文件]...
  2. 打印对每个给定文件的新行、单词和字节计数的结果;如果指定了超过
  3. 一个文件,则还会打印一个总行数。此处的一个单词是指由空白字符分隔的
  4. 长度大于零的字符序列。
  5.  或:wc [选项]... --files0-from=F
  6. 输出每个指定文件的行数、单词计数和字节数,如果指定了
  7. 多于一个文件,继续给出所有相关数据的总计。如果没有指定
  8. 文件,或者文件为"-",则从标准输入读取数据。

常用选项:

  1. -c, --bytes 输出字节数统计
  2. -m, --chars 输出字符数统计
  3. -l, --lines 输出行数统计
  4. --files0-from=文件 从指定文件读取以空字符(NUL)终止的名称;
  5. 如果该文件被指定为 - 则从标准输入读文件名
  6. -L, --max-line-length 显示最长行的长度
  7. -w, --words 显示单词计数
  8. --help 显示此帮助信息并退出
  9. --version 显示版本信息并退出

10. bc计算器

  1. echo 2*3 | bc
  2. -h --help print this usage and exit
  3. -i --interactive force interactive mode
  4. -l --mathlib use the predefined math routines
  5. -q --quiet not print initial banner
  6. -s --standard non-standard bc constructs are errors
  7. -w --warn warn about non-standard bc constructs
  8. -v --version print version information and exit

11.随机字符

  1. cat /dev/urandom | tr -dc a-zA-Z0-9#@ | head -c 13
  2. echo $RANDOM
  3. seq 首数 增量 尾数 生成连续数字 类似于python中的range
  4. seq 10 | sort - R 1-10生成乱序数字

12.反转字符串rev

二、bash的特性

1、命令和文件自动补全

Tab只能补全命令和文件 (RHEL6/Centos6)

2、常见的快捷键

  1. ^c 终止前台运行的程序
  2. ^z 将前台运行的程序挂起到后台
  3. ^d 退出 等价exit
  4. ^l 清屏
  5. ^a |home 光标移到命令行的最前端
  6. ^e |end 光标移到命令行的后端
  7. ^u 删除光标前所有字符
  8. ^k 删除光标后所有字符
  9. ^r 搜索历史命令

3、常用的通配符(重点)

  1. *: 匹配0或多个任意字符
  2. ?: 匹配任意单个字符
  3. [list]: 匹配[list]中的任意单个字符,或者一组单个字符 [a-z]
  4. [!list]: 匹配除list中的任意单个字符
  5. {string1,string2,...}:匹配string1,string2或更多字符串
  6. rm -f file*
  7. cp *.conf /dir1
  8. touch file{1..5}

4、bash中的引号(重点)

  • 双引号”” :会把引号的内容当成整体来看待,允许通过$符号引用其他变量值
  • 单引号’’ :会把引号的内容当成整体来看待,禁止引用其他变量值,shell中特殊符号都被视为普通字符
  • 反撇号`` :反撇号和$()一样,引号或括号里的命令会优先执行,如果存在嵌套,反撇号不能用
  1. [root@MissHou dir1]# echo "$(hostname)"
  2. server
  3. [root@MissHou dir1]# echo '$(hostname)'
  4. $(hostname)
  5. [root@MissHou dir1]# echo "hello world"
  6. hello world
  7. [root@MissHou dir1]# echo 'hello world'
  8. hello world
  9. [root@MissHou dir1]# echo $(date +%F)
  10. 2018-11-22
  11. [root@MissHou dir1]# echo `echo $(date +%F)`
  12. 2018-11-22
  13. [root@MissHou dir1]# echo `date +%F`
  14. 2018-11-22
  15. [root@MissHou dir1]# echo `echo `date +%F``
  16. date +%F
  17. [root@MissHou dir1]# echo $(echo `date +%F`)
  18. 2018-11-22