Go面试—Linux下grep指令常见用法

原文地址:Go面试—Linux下grep指令常见用法

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_namegrep -o AM test.log

统计文件或者文本中包含匹配字符串的行数,如下:

grep -c "text" file_namegrep AM test.log
输出包含匹配字符串的行数,如下:
grep "text" -n file_namecat file_name | grep "text" -ngrep "text" -n file_1 file_2 #多个文件grep AM test.log

打印样式匹配所位于的字符或字节偏移,如下:

grep "text" -b file_namegrep -b AM test.loggrep -b -o AM test.logecho gun is not unix | grep -b -o "not"

搜索多个文件并查找匹配文本在哪些文件中,如下:

grep -l "text" file1 file2 file3...grep -l AB test.log test2.loggrep -l AM test.log test2.log

在多级目录中对文本进行递归搜索,如下:

#.表示当前目录grep "text" . -r

忽略匹配样式中的字符大小写,如下:

grep "am" test.loggrep "am" test.log -igrep "AM" test.log -i

指定多个匹配样式,如下:

grep -e "text" -e "text2" . -igrep -e "AM" -e "AB" test.logecho this is a text line | grep -e "is" -e "line" -oecho 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* -lZgrep "aaa" file* -lgrep "aaa" file* -lZ | xargs -0 rm

grep静默输出,如下:

#不会输出任何信息,如果命令运行成功返回0,失败则返回非0值,一般用于条件测试grep -q "test" filename#显示匹配某个结果之后的3行,使用 -Aseq 10 | grep "5" -A 3#显示匹配某个结果之前的3行,使用 -Bseq 10 | grep "5" -B 3#显示匹配某个结果的前三行和后三行,使用 -Cseq 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

至此,本次分享就结束了,后期会慢慢补充。

以上仅为个人观点,不一定准确,能帮到各位那是最好的。

好啦,到这里本文就结束了,喜欢的话就来个三连击吧。

扫码关注公众号,获取更多优质内容。

  

おすすめ

転載: blog.csdn.net/luyaran/article/details/121293253