清默网络linux班,linux笔记(26)grep

发布时间:2025-12-10 11:45:01 浏览次数:7

正则是一串有规律的字符串grep/egrep egrep是grep的拓展sedawk学好三个命令,对编写shell脚本有很多大帮助

grep 过滤指定关键词grep +参数 'word' filename -c 显示关键词有多少行[root@localhost grep]# grep -c 'nologin' passwd 19

-n 显示关键词所在的行号[root@localhost grep]# grep -n 'nologin' passwd 2:bin:x:1:1:bin:/bin:/sbin/nologin3:daemon:x:2:2:daemon:/sbin:/sbin/nologin4:adm:x:3:4:adm:/var/adm:/sbin/nologin5:lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin9:mail:x:8:12:mail:/var/spool/mail:/sbin/nologin10:operator:x:11:0:operator:/root:/sbin/nologin11:games:x:12:100:games:/usr/games:/sbin/nologin12:ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin13:nobody:x:99:99:Nobody:/:/sbin/nologin14:systemd-bus-proxy:x:999:997:systemd Bus Proxy:/:/sbin/nologin15:systemd-network:x:192:192:systemd Network Management:/:/sbin/nologin16:dbus:x:81:81:System message bus:/:/sbin/nologin17:polkitd:x:998:996:User for polkitd:/:/sbin/nologin18:tss:x:59:59:Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin19:postfix:x:89:89::/var/spool/postfix:/sbin/nologin20:sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin21:chrony:x:997:995::/var/lib/chrony:/sbin/nologin24:user1:x:1111:1000::/home/user222:/sbin/nologin25:user3:x:1010:1000::/home/user111:/sbin/nologin

-i 不区分大小写的过滤关键词

-v 过滤出来没有关键词的行号

-r 遍历所有子目录

-A 后面跟数字,过滤出符合要求的行向下的n行列出来[root@localhost grep]# grep -A2 'root' passwd root:x:0:0:root:/root:/bin/bashbin:x:1:1:bin:/bin:/sbin/nologindaemon:x:2:2:daemon:/sbin:/sbin/nologin

operator:x:11:0:operator:/root:/sbin/nologingames:x:12:100:games:/usr/games:/sbin/nologinftp:x:14:50:FTP User:/var/ftp:/sbin/nologin

-B 后面跟数字,过滤出符合要求的行向上的n行列出来[root@localhost grep]# grep -B2 'root' passwd root:x:0:0:root:/root:/bin/bash

halt:x:7:0:halt:/sbin:/sbin/haltmail:x:8:12:mail:/var/spool/mail:/sbin/nologinoperator:x:11:0:operator:/root:/sbin/nolog

-A 后面跟数字,过滤出符合要求的行上下的n行列出来[root@localhost grep]# grep -C2 'root' passwd root:x:0:0:root:/root:/bin/bashbin:x:1:1:bin:/bin:/sbin/nologindaemon:x:2:2:daemon:/sbin:/sbin/nologin

halt:x:7:0:halt:/sbin:/sbin/haltmail:x:8:12:mail:/var/spool/mail:/sbin/nologinoperator:x:11:0:operator:/root:/sbin/nologingames:x:12:100:games:/usr/games:/sbin/nologinftp:x:14:50:FTP User:/var/ftp:/sbin/nologin

二grep/egrep 示列grep '[2021年05月05日]' passwd 把2021年05月05日的数字过滤出来grep -v '[2021年05月05日]' passwd 没有2021年05月05日的行过滤出来grep -v '^#' /etc/inittab 把不是以#开头的行列出来[root@localhost grep]# grep -vn '^#' inittab 7:dadasdasd13:dadasda

^放到[]外面 表示以***开头,放[^]里面,表示非[]里的字符

grep 'r.o' passwd .表示任意的一个字符 grep 'ro' passwd左边的字符重复0-n次,0次就是没有,则可以匹配到一个o.* 可以匹配到任意的字符

grep 'o{2}' passwd [root@localhost grep]# grep 'o{2}' passwd 过滤2个o的字符,4个o是由2个o组成的,所以也可以匹到root:x:0:0:root:/root:/bin/bashlp:x:4:7:lp:/var/spool/lpd:/sbin/nologinmail:x:8:12:mail:/var/spool/mail:/sbin/nologinoperator:x:11:0:operator:/root:/sbin/nologinpostfix:x:89:89::/var/spool/postfix:/sbin/nologinlty:x:1000:1000::/hoooome/lty:/bin/bash

如果不想输入脱义符,也可以用egrep 'o{2}' passwd

[root@localhost grep]# egrep 'o+o' passwd +号表示左侧的字符重复1次或多次,和*的区别是没有0次,所以一个o匹配不到root:x:0:0:root:/root:/bin/bashlp:x:4:7:lp:/var/spool/lpd:/sbin/nologinmail:x:8:12:mail:/var/spool/mail:/sbin/nologinoperator:x:11:0:operator:/root:/sbin/nologinpostfix:x:89:89::/var/spool/postfix:/sbin/nologinlty:x:1000:1000::/hoooome/lty:/bin/bash

[root@localhost grep]# egrep 'o?1o' passwd ?表示左侧字符重复0次或1次bin:x:1o:1:bin:/bin:/sbin/nologinmail:x:8:o1o2:mail:/var/spool/mail:/sbin/nologin

|[root@localhost grep]# egrep 'root|user' passwd |表示或者的意思root:x:0:0:root:/root:/bin/bashoperator:x:11:0:operator:/root:/sbin/nologintss:x:59:59:Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologinuser1:x:1111:1000::/home/user222:/sbin/nologinuser3:x:1010:1000::/home/user111:/sbin/nologin

需要做网站?需要网络推广?欢迎咨询客户经理 13272073477