L2:grep使用正则表达式

前端之家收集整理的这篇文章主要介绍了L2:grep使用正则表达式前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

本文对grep的使用与正则表达式做相关总结(包含实际演示例子)

1、总结所涉及命令的使用方法及相关示例展示;

命令:

权限管理:

权限管理: chmod

所属关系管理: chown,chgrp

文件遮罩码:umask

Linux文本处理三剑客:

grep: 文本过滤工具;

sed:文本编辑器(行);stream editor

awk:文本报告生成器;Linux上awk的实现为gawk


grep作用:文本搜索工具,根据用户指定的“模式(pattern)”逐行去搜索目标文本,打印匹配到的行;

模式:由正则表达式的元字符及文本字符所编写的过滤条件;


元字符:字符不表示其字面意义,而用于表示通配或控制功能


分两类:

基本正则表达式:BRE

扩展正则表达式:ERE

grep [OPTIONS] PATTERN [FILE...]:

选项:

--color=auto:对匹配到的串做高亮显示

-v:显示模式匹配不到行;

-i: 忽略字符大小写;

-o: 仅显示能够被模式匹配到的串本行;

-q: 静默模式;(常用语脚本判断,有输出$?为0,没输出$?不为0)

-E:使用扩展的正则表达式;

实例演示:

  1. #
  2. [root@zy03~]#grep--color'root'/etc/passwd
  3. root:x:0:0:root:/root:/bin/bash
  4. operator:x:11:0:operator:/root:/sbin/nologin
  5. #不包含nologin行(-v选项)
  6. [root@zy03~]#grep--color-v'nologin'/etc/passwd
  7. root:x:0:0:root:/root:/bin/bash
  8. sync:x:5:0:sync:/sbin:/bin/sync
  9. shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
  10. halt:x:7:0:halt:/sbin:/sbin/halt
  11. a:x:500:531::/home/a:/bin/bash
  12. bash:x:501:532::/home/bash:/bin/bash
  13. testbash:x:502:533::/home/testbash:/bin/bash
  14. basher:x:503:534::/home/basher:/bin/bash
  15. centos:x:505:536::/home/centos:/bin/bash
  16. user1:x:506:537::/home/user1:/bin/bash
  17. #忽略大小写-i
  18. [root@zy03~]#grep--color-i'ROOT'/etc/passwd
  19. root:x:0:0:root:/root:/bin/bash
  20. operator:x:11:0:operator:/root:/sbin/nologin
  21. #仅显示匹配的行
  22. [root@zy03~]#grep--color-o'root'/etc/passwd
  23. root
  24. root
  25. root
  26. root

2、总结基本正则表达式及扩展正则表达式

基本正则表达式的元字符:

字符匹配:

.: 匹配任意单个字符;

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

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


[:lower:],[:upper:],...


次数匹配:用于要指定其次数的字符的后面;

*: 任意次;

\?:0或1次;

grep "x\?y"


\+:1或多次;

\{m\}:精确限制为m次;

\{m,n\}: 至少m次,至多n次,[m,n]

\{0,n\}:至多n次;

\{m,\}:至少m次;


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


位置锚定:

^: 行首锚定;用于模式的最左侧;

$: 行尾锚定;用于模式的最右侧;

\<,\b: 词首锚定;用于表示单词的模式的左侧;

\>,\b:词尾锚定;用于表示单词的模式的右侧;

^$: 空白行;


分组:\(\)


分组的小括号中的模式匹配到的内容,会在执行过程中被正则表达式引擎记录下来,并保存内置的变量中;这些变量分别是\1,\2,...

\1: 从左侧起,第一个左括号,以及与之配对的右括号中间的模式所匹配到的内容

\2:如上类推

...

后向引用:使用变量引用前面的分组括号中的模式所匹配到的字符;


扩展的正则表达式:

grep家庭有三个命令:

grep:基本正则表达式

-E: 扩展正则表达式

-F:不支持正则表达式

egrep:扩展正则表达式

fgrep:不支持正则表达式


扩展正则表达式的元字符:

字符匹配:

.: 任意单个字符

[]:

[^]:


次数匹配:

*

?: 0次或1次;

+: 1次以上;

{m}: 精确匹配m次;

{m,n}: 至少m次,至多n次;


锚定:

^: 锚定行首

$: 锚定行尾

\<,\b

\>,\b


分组:()

后向引用:\1,...

或者:

a|b

C|cat: 不表示Cat或cat,而表示C或cat;

要写成(C|c)at

3,显示/etc/passwd文件中以bash结尾的行

  1. egrep'\<bash\>$'/etc/passwd
  2. root:x:0:0:root:/root:/bin/bash
  3. a:x:500:531::/home/a:/bin/bash
  4. bash:x:501:532::/home/bash:/bin/bash
  5. testbash:x:502:533::/home/testbash:/bin/bash
  6. basher:x:503:534::/home/basher:/bin/bash
  7. centos:x:505:536::/home/centos:/bin/bash
  8. user1:x:506:537::/home/user1:/bin/bash

4、显示/etc/passwd文件中的两位数或三位数

  1. cat/etc/passwd|grep'[0-9]\{2,3\}'|grep-v'[0-9]\{4,\}'
  2. mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
  3. uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
  4. operator:x:11:0:operator:/root:/sbin/nologin
  1. gopher:x:13:30:gopher:/var/gopher:/sbin/nologin
  2. ftp:x:14:50:FTPUser:/var/ftp:/sbin/nologin
  3. nobody:x:99:99:Nobody:/:/sbin/nologin
  4. dbus:x:81:81:Systemmessagebus:/:/sbin/nologin
  5. usbmuxd:x:113:113:usbmuxduser:/:/sbin/nologin
  6. vcsa:x:69:69:virtualconsolememoryowner:/dev:/sbin/nologin
  7. rpc:x:32:32:RpcbindDaemon:/var/cache/rpcbind:/sbin/nologin
  8. rtkit:x:499:497:RealtimeKit:/proc:/sbin/nologin
  9. avahi-autoipd:x:170:170:AvahiIPv4LLStack:/var/lib/avahi-autoipd:/sbin/nologin
  10. abrt:x:173:173::/etc/abrt:/sbin/nologin
  11. rpcuser:x:29:29:RPCServiceUser:/var/lib/nfs:/sbin/nologin
  12. haldaemon:x:68:68:HALdaemon:/:/sbin/nologin
  13. gdm:x:42:42::/var/lib/gdm:/sbin/nologin
  14. ntp:x:38:38::/etc/ntp:/sbin/nologin
  15. apache:x:48:48:Apache:/var/www:/sbin/nologin
  16. saslauth:x:498:76:"Saslauthduser":/var/empty/saslauth:/sbin/nologin
  17. postfix:x:89:89::/var/spool/postfix:/sbin/nologin
  18. pulse:x:497:496:PulseAudioSystemDaemon:/var/run/pulse:/sbin/nologin
  19. sshd:x:74:74:Privilege-separatedSSH:/var/empty/sshd:/sbin/nologin
  20. tcpdump:x:72:72::/:/sbin/nologin
  21. a:x:500:531::/home/a:/bin/bash
  22. bash:x:501:532::/home/bash:/bin/bash
  23. testbash:x:502:533::/home/testbash:/bin/bash
  24. basher:x:503:534::/home/basher:/bin/bash
  25. nologin:x:504:535::/home/nologin:/sbin/nologin
  26. centos:x:505:536::/home/centos:/bin/bash
  27. user1:x:506:537::/home/user1:/bin/bash

5、显示`netstat -tan`命令结果中以‘LISTEN’后跟0个、1个或者多个空白字符结尾的行

  1. 1netstat-tan|grep'LISTEN[[:space:]]\{0,\}'
  2. 2netstat-tan|egrep'LISTEN[[:space:]]?+$'
  3.  
  4. tcp000.0.0.0:1110.0.0.0:*LISTEN
  5. tcp000.0.0.0:220.0.0.0:*LISTEN
  6. tcp00127.0.0.1:6310.0.0.0:*LISTEN
  7. tcp00127.0.0.1:250.0.0.0:*LISTEN
  8. tcp000.0.0.0:592260.0.0.0:*LISTEN
  9. tcp00:::111:::*LISTEN
  10. tcp00:::22:::*LISTEN
  11. tcp00::1:631:::*LISTEN
  12. tcp00::1:25:::*LISTEN
  13. tcp00:::47009:::*LISTEN

6、添加用户bash、testbash、basher以及nologin用户(nologin用户的shell为/sbin/nologin);而后找出/etc/passwd文件用户名与其shell名相同的行

  1. egrep--color'(\b^[[:alnum:]]+\b).*\1$'/etc/passwd
  2. sync:x:5:0:sync:/sbin:/bin/sync
  3. shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
  4. halt:x:7:0:halt:/sbin:/sbin/halt
  5. bash:x:501:532::/home/bash:/bin/bash
  6. nologin:x:504:535::/home/nologin:/sbin/nologin

7、显示当前系统上root、centos或者user1用户的默认shell和UID (请事先创建这些用户,若不存在)

  1. grep-E'^root|^centos|^user1'/etc/passwd|cut-d:-f1,3,7
  2. root:0:/bin/bash
  3. centos:505:/bin/bash
  4. user1:506:/bin/bash

8、找出/etc/rc.d/init.d/functions文件中某单词(单词中间可以存在下划线)后面跟着一组小括号的行

  1. grep'.*()'/etc/rc.d/init.d/functions
  2. echo_passed(){
  3. echo_warning(){grep'.*()'/etc/rc.d/init.d/functions
  4. fstab_decode_str(){
  5. checkpid(){
  6. __readlink(){
  7. __fgrep(){
  8. __umount_loop(){
  9. __umount_loopback_loop(){
  10. __pids_var_run(){
  11. __pids_pidof(){
  12. daemon(){
  13. killproc(){
  14. pidfileofproc(){
  15. pidofproc(){
  16. status(){
  17. echo_success(){
  18. echo_failure(){
  19. update_boot_stage(){
  20. success(){
  21. failure(){
  22. passed(){
  23. warning(){
  24. action(){
  25. strstr(){
  26. confirm(){
  27. get_numeric_dev(){
  28. is_ignored_file(){
  29. is_true(){
  30. is_false(){
  31. apply_sysctl(){
  32. key_is_random(){
  33. find_crypto_mount_point(){
  34. init_crypto(){

9、使用echo输出一个路径,而后egrep找出其路径基名;进一步的使用egrep取出其目录名

  1. echo"/etc/sysconfig/network"|egrep--color-o'[[:alnum:]]+$'
  2. network
  3. echo"/etc/sysconfig/network"|egrep--color-o'.*/'
  4. /etc/sysconfig/

10,找出ifconfig命令执行结果中1-255之间的数字

  1. ifconfig|egrep--color=auto"\<[12][0-9][0-9]\>|\<[1-9][0-9]\>|\<[1-9]\>"
  2. eth0Linkencap:EthernetHWaddr52:54:00:A3:D2:58
  3. inetaddr:192.168.0.96Bcast:192.168.0.255Mask:255.255.255.0
  4. inet6addr:fe80::5054:ff:fea3:d258/64Scope:Link
  5. UPBROADCASTRUNNINGMULTICASTMTU:1500Metric:1
  6. RXbytes:117052479(111.6MiB)TXbytes:3472613(3.3MiB)
  7. inetaddr:127.0.0.1Mask:255.0.0.0
  8. inet6addr:::1/128Scope:Host
  9. UPLOOPBACKRUNNINGMTU:16436Metric:1
  10. RXpackets:44errors:0dropped:0overruns:0frame:0
  11. TXpackets:44errors:0dropped:0overruns:0carrier:0
  12. RXbytes:2990(2.9KiB)TXbytes:2990(2.9KiB)

猜你在找的正则表达式相关文章