目录
-o 选项 --》 只显示匹配的内容 --only-matching
-i 选项 --》 忽略大小写,都匹配显示出来 --ignore-case
-n 选项 --》 给匹配的内容加行号 --line-number
-v 选项: 反转查找,输出与模式不相符的内容 --invert-match
-A + 长度 : after 显示出匹配内容以及它的后面几行
-C + 长度 :centre显示匹配内容并且显示他的前后几行内容
区别:扩展正则支持更加多的元字符,能够表达更复杂的意思,功能更加强大
grep 通用正则表达式分析程序(global search regular expression and printing)
用途:使用正则表达式搜索文本,并把匹配的行列打印出来
格式:grep [选项]... 模式 目标文件
######################################################
^...: 以什么开头,整行以什么开头
...$ : 以什么结尾,整行以什么结尾
主要是一些字符串 + 数字 + 特殊符号,组成一个模式
用来表示某个意思
######################################################
-i : 查找时忽略大小写
-v: 反转查找,输出与模式不相符的行
-n : 显示符合模式要求的行号
-r : 递归搜索所有文件
-o : 只显示匹配的内容
-E : 支持更多的元字符,支持扩展正则
-A :显示匹配内容以及它的后面几行内容
-B ; 显示匹配内容以及它的前面几行内容
-C:显示匹配内容并且显示他的前后几行内容
######################################################
示例:查看/etc/passwd文件里面所有的sbin
1)不加 -o时候:会将匹配内容的那一行全部输出出来
- [root@localhost script]# cat /etc/passwd | grep "sbin"
- bin:x:1:1:bin:/bin:/sbin/nologin
- daemon:x:2:2:daemon:/sbin:/sbin/nologin
- adm:x:3:4:adm:/var/adm:/sbin/nologin
- lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
- sync:x:5:0:sync:/sbin:/bin/sync
- shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
- halt:x:7:0:halt:/sbin:/sbin/halt
- mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
- operator:x:11:0:operator:/root:/sbin/nologin
- games:x:12:100:games:/usr/games:/sbin/nologin
- ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
- nobody:x:99:99:Nobody:/:/sbin/nologin
- systemd-network:x:192:192:systemd Network Management:/:/sbin/nologin
- dbus:x:81:81:System message bus:/:/sbin/nologin
- polkitd:x:999:998:User for polkitd:/:/sbin/nologin
- sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
- postfix:x:89:89::/var/spool/postfix:/sbin/nologin
- chrony:x:998:996::/var/lib/chrony:/sbin/nologin
- nginx:x:997:995:Nginx web server:/var/lib/nginx:/sbin/nologin
- tss:x:59:59:Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin
- ntp:x:38:38::/etc/ntp:/sbin/nologin
2)加-o的时候:只会输出匹配的内容
- [root@localhost script]# cat /etc/passwd | grep -o "sbin"
- sbin
- sbin
- sbin
- sbin
- sbin
- sbin
- sbin
- sbin
- sbin
- sbin
- sbin
- sbin
- sbin
######################################################
- [root@localhost script]# cat phone.txt | grep xiaomi
- xiaomi
- [root@localhost script]# cat phone.txt | grep -i xiaomi
- xiaomi
- XIAOMI
- [root@localhost script]# cat phone.txt | grep -ni xiaomi
- 1:xiaomi
- 2:XIAOMI
######################################################
当我们不接-v选项的时候:只会输出匹配的内容
- [root@localhost script]# cat phone.txt | grep "xiaomi"
- xiaomi
当我们接-v选项的时候:反转查找输出与模式不相符的内容
- [root@localhost script]# cat phone.txt | grep -v "xiaomi"
- XIAOMI
- huawei
- HUAWEI OPPO vivo
- VIVO
- apple meizu kupai
- nokia
######################################################
递归查找,会将目录下所有文件一层一层查找
######################################################
- [root@localhost script]# cat phone.txt | grep -A 3 huawei
-
- huawei
-
- HUAWEI OPPO vivo
-
- VIVO
-
- apple meizu kupai
######################################################
- [root@localhost script]# cat phone.txt | grep -B 2 huawei
-
- xiaomi
-
- XIAOMI
-
- huawei
grep在匹配字符的时候,是模糊匹配
######################################################
[root@localhost script]# cat phone.txt | grep -C 2 huawei
xiaomi
XIAOMI
huawei
HUAWEI OPPO vivo
VIVO
######################################################
egrep = grep -E
元字符:有特殊作用的字符
元字符:* . ^ $
元字符:| + ? {}
扩展正则: -E, --extended-regexp
在基本正则的基础上新加了很多的元字符,例如 :
|表示或者
因为grep默认只支持基本正则,所以在用到扩展正则的时候要加-E
Interpret PATTERN as an extended regular expression (ERE, see below)
######################################################
例: 查找出 以root开头或者feng[1-5]的信息
因为有或,所以要用到 | 符号,|属于扩展正则,要接 -E
注意 | 两边不要空格
- root@localhost lianxi]# cat /etc/passwd | grep -E ^root|feng[0-5]
- root:x:0:0:root:/root:/bin/bash
- feng1:x:1017:1017::/home/feng1:/bin/bash
- feng2:x:1018:1018::/home/feng2:/bin/bash
- feng3:x:1019:1019::/home/feng3:/bin/bash
- feng4:x:1020:1020::/home/feng4:/bin/bash
- feng5:x:1021:1021::/home/feng5:/bin/bash
######################################################
^$ 表示空行
例: 查找出来sshd_config配置文件里的有效行
有效行:不是注释和空行
以# 开头的都是注释
- [root@localhost lianxi]# cat /etc/ssh/sshd_config | grep -vE ^#|^$
- HostKey /etc/ssh/ssh_host_rsa_key
- HostKey /etc/ssh/ssh_host_ecdsa_key
- HostKey /etc/ssh/ssh_host_ed25519_key
- SyslogFacility AUTHPRIV
- AuthorizedKeysFile .ssh/authorized_keys
- PasswordAuthentication yes
- ChallengeResponseAuthentication no
- GSSAPIAuthentication yes
- GSSAPICleanupCredentials no
- UsePAM yes
- X11Forwarding yes
- AcceptEnv LANG LC_CTYPE LC_NUMERIC LC_TIME LC_COLLATE LC_MONETARY LC_MESSAGES
- AcceptEnv LC_PAPER LC_NAME LC_ADDRESS LC_TELEPHONE LC_MEASUREMENT
- AcceptEnv LC_IDENTIFICATION LC_ALL LANGUAGE
- AcceptEnv XMODIFIERS
- Subsystem sftp /usr/libexec/openssh/sftp-server
######################################################