grep是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来,语法格式如下:
grep [-abcEFGhHilLnqrsvVwxy][-A<显示列数>][-B<显示列数>][-C<显示列数>][-d<进行动作>][-e<范本样式>][-f<范本文件>][--help][范本样式][文件或目录...]
参数说明:
-a或--text 不要忽略二进制的数据。
-A<显示列数>或--after-context=<显示列数> 除了显示符合范本样式的那一列之外,并显示该列之后的内容。
-b或--byte-offset 在显示符合范本样式的那一列之前,标示出该列第一个字符的位编号。
-B<显示列数>或--before-context=<显示列数> 除了显示符合范本样式的那一列之外,并显示该列之前的内容。
-c或--count 计算符合范本样式的列数。
-C<显示列数>或--context=<显示列数>或-<显示列数> 除了显示符合范本样式的那一列之外,并显示该列之前后的内容。
-d<进行动作>或--directories=<进行动作> 当指定要查找的是目录而非文件时,必须使用这项参数,否则grep指令将回报信息并停止动作。
-e<范本样式>或--regexp=<范本样式> 指定字符串做为查找文件内容的范本样式。
-E或--extended-regexp 将范本样式为延伸的普通表示法来使用。
-f<范本文件>或--file=<范本文件> 指定范本文件,其内容含有一个或多个范本样式,让grep查找符合范本条件的文件内容,格式为每列一个范本样式。
-F或--fixed-regexp 将范本样式视为固定字符串的列表。
-G或--basic-regexp 将范本样式视为普通的表示法来使用。
-h或--no-filename 在显示符合范本样式的那一列之前,不标示该列所属的文件名称。
-H或--with-filename 在显示符合范本样式的那一列之前,表示该列所属的文件名称。
-i或--ignore-case 忽略字符大小写的差别。
-l或--file-with-matches 列出文件内容符合指定的范本样式的文件名称。
-L或--files-without-match 列出文件内容不符合指定的范本样式的文件名称。
-n或--line-number 在显示符合范本样式的那一列之前,标示出该列的列数编号。
-q或--quiet或--silent 不显示任何信息。
-r或--recursive 此参数的效果和指定"-d recurse"参数相同。
-s或--no-messages 不显示错误信息。
-v或--revert-match 反转查找。
-V或--version 显示版本信息。
-w或--word-regexp 只显示全字符合的列。
-x或--line-regexp 只显示全列符合的列。
-y 此参数的效果和指定"-i"参数相同。
--help 在线帮助。
在多个文件中搜索一个单词,命令会返回一个包含【asd】的文本行,如下:
grep asd file_1 file_2 file_3 ...
grep "asd" file_1 file_2 file_3 ...
输出除【asd】之外的所有行,如下:
grep -v "asd" file_name
标记匹配颜色,如下:
grep "asd" file_name --color=auto
使用正则表达式,如下:
grep -E "[1-9]+"
egrep "[1-9]+"
搜索以数字9开头的行,如下:
grep -E "^9" test.log
只输出文件中匹配到的部分,如下:
grep -o match_pattern file_name
grep -o AM test.log
统计文件或者文本中包含匹配字符串的行数,如下:
grep -c "text" file_name
grep AM test.log
输出包含匹配字符串的行数,如下:
grep "text" -n file_name
cat file_name | grep "text" -n
grep "text" -n file_1 file_2 #多个文件
grep AM test.log
打印样式匹配所位于的字符或字节偏移,如下:
grep "text" -b file_name
grep -b AM test.log
grep -b -o AM test.log
echo gun is not unix | grep -b -o "not"
搜索多个文件并查找匹配文本在哪些文件中,如下:
grep -l "text" file1 file2 file3...
grep -l AB test.log test2.log
grep -l AM test.log test2.log
在多级目录中对文本进行递归搜索,如下:
#.表示当前目录
grep "text" . -r
忽略匹配样式中的字符大小写,如下:
grep "am" test.log
grep "am" test.log -i
grep "AM" test.log -i
指定多个匹配样式,如下:
grep -e "text" -e "text2" . -i
grep -e "AM" -e "AB" test.log
echo this is a text line | grep -e "is" -e "line" -o
echo aaa bbb ccc ddd eee | grep -f patfile -o
在grep搜索结果中包括或者排除指定文件,如下:
#只在目录中test3.log和test4.log文件中递归搜索字符"KS"
grep "KS" . -r --include=test{3,4}.log
#在搜索结果中排除所有README文件
grep "main()" . -r --exclude "README"
#在搜索结果中排除所有README文件
grep "main()" . -r --exclude "README"
#在搜索结果中排除filelist文件列表里的文件
grep "main()" . -r --exclude-from filelist
使用0值字节后缀的grep与xargs,如下:
grep "aaa" file* -lZ
grep "aaa" file* -l
grep "aaa" file* -lZ | xargs -0 rm
grep静默输出,如下:
#不会输出任何信息,如果命令运行成功返回0,失败则返回非0值,一般用于条件测试
grep -q "test" filename
#显示匹配某个结果之后的3行,使用 -A
seq 10 | grep "5" -A 3
#显示匹配某个结果之前的3行,使用 -B
seq 10 | grep "5" -B 3
#显示匹配某个结果的前三行和后三行,使用 -C
seq 10 | grep "5" -C 3
#如果匹配结果有多个,会用“--”作为各匹配结果之间的分隔符
echo -e "a\nb\nc\na\nb\nc"
echo -e "a\nb\nc\na\nb\nc" | grep a -A 1
至此,本次分享就结束了,后期会慢慢补充。
以上仅为个人观点,不一定准确,能帮到各位那是最好的。
好啦,到这里本文就结束了,喜欢的话就来个三连击吧。
扫码关注公众号,获取更多优质内容。