关键参数
grep -f --file=FILE 从 FILE 中取得 PATTERN
语法
grep -f file1 file2
从file2中过滤出包含file1的任意行的行,最终结果得到的是file2中的部分内容,什么意思呢,举个例子就明白了。
举例
file1是a.txt,内容如下:
[root@localhost shell]# cat a.txt
111
222
aaa
vvv
root
/bin/bash
[root@localhost shell]#
file2是/etc/passwd,内容如下:
[root@localhost shell]# cat /etc/passwd
root:x:0:0:root:/root:/bin/bash
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
uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
gopher:x:13:30:gopher:/var/gopher:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
nobody:x:99:99:Nobody:/:/sbin/nologin
dbus:x:81:81:System message bus:/:/sbin/nologin
usbmuxd:x:113:113:usbmuxd user:/:/sbin/nologin
vcsa:x:69:69:virtual console memory owner:/dev:/sbin/nologin
rpc:x:32:32:Rpcbind Daemon:/var/cache/rpcbind:/sbin/nologin
rtkit:x:499:497:RealtimeKit:/proc:/sbin/nologin
avahi-autoipd:x:170:170:Avahi IPv4LL Stack:/var/lib/avahi-autoipd:/sbin/nologin
abrt:x:173:173::/etc/abrt:/sbin/nologin
rpcuser:x:29:29:RPC Service User:/var/lib/nfs:/sbin/nologin
nfsnobody:x:65534:65534:Anonymous NFS User:/var/lib/nfs:/sbin/nologin
haldaemon:x:68:68:HAL daemon:/:/sbin/nologin
gdm:x:42:42::/var/lib/gdm:/sbin/nologin
ntp:x:38:38::/etc/ntp:/sbin/nologin
apache:x:48:48:Apache:/var/www:/sbin/nologin
saslauth:x:498:76:"Saslauthd user":/var/empty/saslauth:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
pulse:x:497:496:PulseAudio System Daemon:/var/run/pulse:/sbin/nologin
sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
tcpdump:x:72:72::/:/sbin/nologin
huanzi:x:500:500:huanzi:/home/huanzi:/bin/bash
user1:x:501:501::/home/user1:/bin/bash
[root@localhost shell]#
执行结果如下:
[root@localhost shell]# grep -f a.txt /etc/passwd
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin
huanzi:x:500:500:huanzi:/home/huanzi:/bin/bash
user1:x:501:501::/home/user1:/bin/bash
[root@localhost shell]#
能看出来,/etc/passwd中包含root和/bin/bash的行都被过滤了出来。
取反对比
grep -vf file1 file2
解释:过滤出file2中不包含file1任意行的行,最终结果是file2的部分内容。比较拗口,继续举例。
举例
[root@localhost shell]# cat a.txt
111
222
aaa
vvv
root
/bin/bash
qq
[root@localhost shell]# cat b.txt
aaa
root
qqq
www
1234545
11
[root@localhost shell]# grep -vf a.txt b.txt //b.txt中有,但是a.txt中没有的那些内容,最终结果是b的部分内容
www
1234545
11
[root@localhost shell]# grep -vf b.txt a.txt //a.txt中有,但是b.txt中没有的那些内容,最终结果是a的部分内容
222
vvv
/bin/bash
qq
[root@localhost shell]#
继续扩展
上面可以看到,a.txt中的qq和b.txt中的qqq匹配到一起了(b中的11和a中的111也匹配了),要精准匹配,加上以下参数。
grep -w
w的意思是word,要严格匹配,一字不差。
举例
[root@localhost shell]# grep -vwf a.txt b.txt
qqq
www
1234545
11
[root@localhost shell]# grep -vwf b.txt a.txt
111
222
vvv
/bin/bash
qq
[root@localhost shell]#
感谢各位大佬查看,欢迎积极指正。