也想出现在这里? 联系我们

Linux文本匹配命令grep与fgrep使用完全讲解

作者 : 小编 本文共7811个字,预计阅读时间需要20分钟 发布时间: 2022-10-29 共1.99K人阅读
也想出现在这里? 联系我们

grep

grep (global search regular expression(RE) and print out the line,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。Unix的grep家族包括grep、egrep和fgrep。egrep和fgrep的命令只跟grep有很小不同。egrep是grep的扩展,支持更多的re元字符, fgrep就是fixed grep或fast grep,它们把所有的字母都看作单词,也就是说,正则表达式中的元字符表示回其自身的字面意义,不再特殊。Linux使用GNU版本的grep。它功能更强,可以通过-G、-E、-F命令行选项来使用egrep和fgrep的功能。

grep的工作方式是这样的,它在一个或多个文件中搜索字符串模板。如果模板包括空格,则必须被引用,模板后的所有字符串被看作文件名。搜索的结果被送到屏幕,不影响原文件内容。

grep可用于shell脚本,因为grep通过返回一个状态值来说明搜索的状态,如果模板搜索成功,则返回0,如果搜索不成功,则返回1,如果搜索的文件不存在,则返回2。我们利用这些返回值就可进行一些自动化的文本处理工作。

grep –help匹配模式选择:-E, –extended-regexp 扩展正则表达式egrep-F, –fixed-strings 一个换行符分隔的字符串的集合fgrep-G, –basic-regexp 基本正则-P, –perl-regexp 调用的perl正则-e, –regexp=PATTERN 后面根正则模式,默认无-f, –file=FILE 从文件中获得匹配模式-i, –ignore-case 不区分大小写-w, –word-regexp 匹配整个单词-x, –line-regexp 匹配整行-z, –null-data 一个 0 字节的数据行,但不是空行

杂项:-s, –no-messages 不显示错误信息-v, –invert-match 显示不匹配的行-V, –version 显示版本号–help 显示帮助信息–mmap use memory-mapped input if possible

输入控制:-m, –max-count=NUM 匹配的最大数-b, –byte-offset 打印匹配行前面打印该行所在的块号码。-n, –line-number 显示的加上匹配所在的行号–line-buffered 刷新输出每一行-H, –with-filename 当搜索多个文件时,显示匹配文件名前缀-h, –no-filename 当搜索多个文件时,不显示匹配文件名前缀–label=LABEL print LABEL as filename for standard input-o, –only-matching 只显示一行中匹配PATTERN 的部分-q, –quiet, –silent 不显示任何东西–binary-files=TYPE 假定二进制文件的TYPE 类型; TYPE 可以是`binary\’, `text\’, 或`without-match\’-a, –text 匹配二进制的东西-I 不匹配二进制的东西-d, –directories=ACTION 目录操作,读取,递归,跳过-D, –devices=ACTION 设置对设备,FIFO,管道的操作,读取,跳过-R, -r, –recursive 递归调用–include=PATTERN 只查找匹配FILE_PATTERN 的文件–exclude=PATTERN 跳过匹配FILE_PATTERN 的文件和目录–exclude-from=FILE 跳过所有除FILE 以外的文件-L, –files-without-match 匹配多个文件时,显示不匹配的文件名-l, –files-with-matches 匹配多个文件时,显示匹配的文件名-c, –count 显示匹配了多少次-Z, –null 在FILE 文件最后打印空字符

文件控制:-B, –before-context=NUM 打印匹配本身以及前面的几个行由NUM控制-A, –after-context=NUM 打印匹配本身以及随后的几个行由NUM控制-C, –context=NUM 打印匹配本身以及随后,前面的几个行由NUM控制-NUM 根-C的用法一样的–color[=WHEN],–colour[=WHEN] 使用标志高亮匹配字串;-U, –binary 使用标志高亮匹配字串;-u, –unix-byte-offsets 当CR 字符不存在,报告字节偏移(MSDOS 模式)

例:测试文件

复制代码

代码如下:

root:x:0:0:root:/root:/bin/bashbin:x:1:1:bin:/bin:/bin/false,aaa,bbbb,cccc,aaaaaaDADddd:x:2:2:daemon:/sbin:/bin/falsemail:x:8:12:mail:/var/spool/mail:/bin/falseftp:x:14:11:ftp:/home/ftp:/bin/false&nobody:$:99:99:nobody:/:/bin/falsezhangy:x:1000:100:,,,:/home/zhangy:/bin/bashhttp:x:33:33::/srv/http:/bin/falsedbus:x:81:81:System message bus:/:/bin/falsehal:x:82:82:HAL daemon:/:/bin/falsemysql:x:89:89::/var/lib/mysql:/bin/falseaaa:x:1001:1001::/home/aaa:/bin/bashba:x:1002:1002::/home/zhangy:/bin/bashtest:x:1003:1003::/home/test:/bin/bash@zhangying:*:1004:1004::/home/test:/bin/bashpolicykit:x:102:1005:Po

a,匹配含有root的行

复制代码

代码如下:

[root@krlcgcms01 test]# grep root test root:x:0:0:root:/root:/bin/bash

b,匹配以root开头或者以zhang开头的行,注意反斜杠

复制代码

代码如下:

[root@krlcgcms01 test]# cat test |grep \’^\\(root\\|zhang\\)\’ root:x:0:0:root:/root:/bin/bash zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash

c,匹配以root开头或者以zhang开头的行,注意反斜杠,根上面一个例子一样,-e默认是省去的

[root@krlcgcms01 test]# cat test |grep -e \’^\\(root\\|zhang\\)\’ root:x:0:0:root:/root:/bin/bash zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash d,匹配以zhang开头,只含有字母

复制代码

代码如下:

[root@krlcgcms01 test]# echo \’zhangying\’ |grep \’^zhang[a-z]*$\’ zhangying

e,匹配以bin开头的行,用的egrep,在这里可以换成-F,-G

复制代码

代码如下:

[root@krlcgcms01 test]# cat test |grep -E \’^bin\’ bin:x:1:1:bin:/bin:/bin/false,aaa,bbbb,cccc,aaaaaa

f,在匹配的行前面加上该行在文件中,或者输出中所在的行号

复制代码

代码如下:

[root@krlcgcms01 test]# cat test|grep -n zhangy 7:zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash 13:ba:x:1002:1002::/home/zhangy:/bin/bash 15:@zhangying:*:1004:1004::/home/test:/bin/bash

g,不匹配以bin开头的行,并显示行号

复制代码

代码如下:

[root@krlcgcms01 test]# cat test|grep -nv \’^bin\’ root:x:0:0:root:/root:/bin/bashDADddd:x:2:2:daemon:/sbin:/bin/falsemail:x:8:12:mail:/var/spool/mail:/bin/falseftp:x:14:11:ftp:/home/ftp:/bin/false&nobody:$:99:99:nobody:/:/bin/falsezhangy:x:1000:100:,,,:/home/zhangy:/bin/bashhttp:x:33:33::/srv/http:/bin/falsedbus:x:81:81:System message bus:/:/bin/falsehal:x:82:82:HAL daemon:/:/bin/falsemysql:x:89:89::/var/lib/mysql:/bin/falseaaa:x:1001:1001::/home/aaa:/bin/bashba:x:1002:1002::/home/zhangy:/bin/bashtest:x:1003:1003::/home/test:/bin/bash@zhangying:*:1004:1004::/home/test:/bin/bashpolicykit:x:102:1005:Po

h,显示匹配的个数,不显示内容

复制代码

代码如下:

[root@krlcgcms01 test]# cat test|grep -c zhang 3

i,匹配system,没有加-i没有匹配到东西。

复制代码

代码如下:

[root@krlcgcms01 test]# grep system test [root@krlcgcms01 test]# grep -ni system test 9:dbus:x:81:81:System message bus:/:/bin/false

j,匹配zhan没有匹配到东西,匹配zhangy能匹配到,因为在test文件中,有zhangy这个单词

复制代码

代码如下:

[root@krlcgcms01 test]# cat test|grep -w zhan [root@krlcgcms01 test]# cat test|grep -w zhangy zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash ba:x:1002:1002::/home/zhangy:/bin/bash

k,在这里-x后面东西,和输出中的整行相同时,才会输出

[root@krlcgcms01 test]# echo "aaaaaa" |grep -x aaa [root@krlcgcms01 test]# echo "aaaa" |grep -x aaaa aaaa l,最多只匹配一次,如果把-m 1去掉的话,会有三个

复制代码

代码如下:

[root@krlcgcms01 test]# cat test |grep -m 1 zhang zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash

m,匹配行的前面显示块号,这个块号是干什么的,不知道,有谁知道可否告诉我一下

复制代码

代码如下:

[apacheuser@krlcgcms01 test]$ cat test |grep -b zha 241:zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash 480:ba:x:1002:1002::/home/zhangy:/bin/bash 558:@zhangying:*:1004:1004::/home/test:/bin/bash

n,多文件匹配时,在匹配的行前面加上文件名

复制代码

代码如下:

[apacheuser@krlcgcms01 test]$ grep -H \’root\’ test test2 testbak test:root:x:0:0:root:/root:/bin/bash test2:root testbak:root:x:0:0:root:/root:/bin/bash

o,多文件匹配时,在匹配的行前面不加上文件名

复制代码

代码如下:

[apacheuser@krlcgcms01 test]$ grep -h \’root\’ test test2 testbak root:x:0:0:root:/root:/bin/bash root root:x:0:0:root:/root:/bin/bash

p,多文件匹配时,显示匹配文件的文件名

复制代码

代码如下:

[apacheuser@krlcgcms01 test]$ grep -l \’root\’ test test2 testbak DAta test test2 testbak

q,没有-o时,有一行匹配,这一行里面有3个root,加上-o后,这个3个root就出来了

复制代码

代码如下:

[apacheuser@krlcgcms01 test]$ grep \’root\’ test root:x:0:0:root:/root:/bin/bash [apacheuser@krlcgcms01 test]$ grep -o \’root\’ test root root root

r,递归显示匹配的内容,在test目录下面建个mytest目录,copy test目录下面的test文件到mytest下面,能看到上面的结果

复制代码

代码如下:

[root@krlcgcms01 test]# grep test -R /tmp/test/mytest /tmp/test/mytest/test:test:x:1003:1003::/home/test:/bin/bash /tmp/test/mytest/test:@zhangying:*:1004:1004::/home/test:/bin/bash

s,显示匹配root后面的3行

复制代码

代码如下:

[root@krlcgcms01 test]# cat test |grep -A 3 root root:x:0:0:root:/root:/bin/bash bin:x:1:1:bin:/bin:/bin/false,aaa,bbbb,cccc,aaaaaa daemon:x:2:2:daemon:/sbin:/bin/false mail:x:8:12:mail:/var/spool/mail:/bin/false

fgrep用法: fgrep [选项]… PATTERN [FILE]…在每个 FILE 或是标准输入中查找 PATTERN。PATTERN 是一组由断行符分隔的定长字符串。例如: fgrep -i \’hello world\’ menu.h main.c

正则表达式选择与解释: -e, –regexp=PATTERN 用 PATTERN 来进行匹配操作 -f, –file=FILE 从 FILE 中取得 PATTERN -i, –ignore-case 忽略大小写 -w, –word-regexp 强制 PATTERN 仅完全匹配字词 -x, –line-regexp 强制 PATTERN 仅完全匹配一行 -z, –null-data 一个 0 字节的数据行,但不是空行

杂项: -s, –no-messages 不显示错误信息 -v, –invert-match 选中不匹配的行 -V, –version 显示版本信息并退出 –help 显示此帮助并退出 –mmap 忽略向后兼容性

Output control: -m, –max-count=NUM 匹配的最大数 -b, –byte-offset 打印匹配行前面打印该行所在的块号码 -n, –line-number 显示的加上匹配所在的行号 –line-buffered 刷新输出每一行 -H, –with-filename 当搜索多个文件时,显示匹配文件名前缀 -h, –no-filename 当搜索多个文件时,不显示匹配文件名前缀 –label=LABEL use LABEL as the standard input file name prefix -o, –only-matching 只显示一行中匹配PATTERN 的部分 -q, –quiet, –silent 不显示所有输出 –binary-files=TYPE 假定二进制文件的TYPE 类型; TYPE 可以是`binary\’, `text\’, 或`without-match\’ -a, –text 等同于 –binary-files=text -I 等同于 –binary-files=without-match -d, –directories=ACTION 操作目录的方式; ACTION 可以是`read\’, `recurse\’,或`skip\’ -D, –devices=ACTION 操作设备、先入先出队列、套接字的方式; ACTION 可以是`read\’或`skip\’ -R, -r, –recursive 等同于 –directories=recurse –include=FILE_PATTERN 只查找匹配FILE_PATTERN 的文件 –exclude=FILE_PATTERN 跳过匹配FILE_PATTERN 的文件和目录 –exclude-from=FILE 跳过所有除FILE 以外的文件 –exclude-dir=PATTERN 跳过所有匹配PATTERN 的目录。 -L, –files-without-match 只打印不匹配FILEs 的文件名 -l, –files-with-matches 只打印匹配FILES 的文件名 -c, –count 只打印每个FILE 中的匹配行数目 -T, –initial-tab 行首tabs 分隔(如有必要) -Z, –null 在FILE 文件最后打印空字符

文件控制: -B, –before-context=NUM 打印以文本起始的NUM 行 -A, –after-context=NUM 打印以文本结尾的NUM 行 -C, –context=NUM 打印输出文本NUM 行 -NUM 等同于 –context=NUM –color[=WHEN], –colour[=WHEN] 使用标志高亮匹配字串; WHEN 可以是`always\’, `never\’或`auto\’ -U, –binary 不要清除行尾的CR 字符(MSDOS 模式) -u, –unix-byte-offsets 当CR 字符不存在,报告字节偏移(MSDOS 模式)

‘fgrep’已不再使用了;请用 ‘grep -F’代替。不带 FILE 参数,或是 FILE 为 -,将读取标准输入。如果少于两个 FILE 参数就要默认使用 -h 参数。如果选中任意一行,那退出状态为 0,否则为 1;如果有错误产生,且未指定 -q 参数,那退出状态为 2。例:

复制代码

代码如下:

[root@linux test]# cat abc.sh |fgrep a #匹配含有a的行

1. 本站所提供的源码模板(主题/插件)等资源仅供学习交流,若使用商业用途,请购买正版授权,否则产生的一切后果将由下载用户自行承担,有部分资源为网上收集或仿制而来,若模板侵犯了您的合法权益,请来信通知我们(Email: rayer@88.com),我们会及时删除,给您带来的不便,我们深表歉意!
2. 分享目的仅供大家学习和交流,请不要用于商业用途!
3. 如果你也有好源码或者教程,可以到用户中心发布投稿,分享有金币奖励和额外收入!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务 请大家谅解!
5. 如有链接无法下载、失效或广告,请联系站长,可领回失去的金币,并额外有奖!
6. 如遇到加密压缩包,默认解压密码为"www.zyfx8.cn",如遇到无法解压的请联系管理员!
本站部分文章、资源来自互联网,版权归原作者及网站所有,如果侵犯了您的权利,请及时联系我站删除。免责声明
资源分享吧 » Linux文本匹配命令grep与fgrep使用完全讲解

常见问题FAQ

免费下载或者VIP会员专享资源能否直接商用?
本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
织梦模板使用说明
你下载的织梦模板并不包括DedeCMS使用授权,根据DedeCMS授权协议,除个人非盈利站点外,均需购买DedeCMS商业使用授权。购买地址: http://www.desdev.cn/service-dedecms.html

发表评论

Copyright 2015-2020 版权所有 资源分享吧 Rights Reserved. 蜀ICP备14022927号-1
开通VIP 享更多特权,建议使用QQ登录