当前位置: 代码迷 >> 综合 >> 【Liunx】grep操作命令用法总结
  详细解决方案

【Liunx】grep操作命令用法总结

热度:53   发布时间:2023-12-06 04:30:37.0

最近因为项目更新,需要检测一下有没有测试遗漏的bug,所以频繁的使用了grep命令,接下来对这个命令进行一些总结归纳。

1.基础使用

grep 搜索内容 文件名

示例

 1.查询项目错误日志中errors存在的语句(grep 'errors' huijiePmsLog.log)root@VM-0-13-ubuntu:/usr/local/tomcat/systemLog# grep 'errors' huijiePmsLog.log出错类: (org.codehaus.groovy.grails.web.errors.GrailsExceptionResolver)错误描述:- POST请求->errors/systemError:[id:ff808181-7f06bdde-017f-1a91c10f-7daa]

 2.grep命令归纳总结

示例

# 在文件中搜索一个单词,命令会返回一个包含“match_pattern”的文本行:
grep match_pattern file_name	
grep "match_pattern" file_name# 在多个文件中查找
grep "match_pattern" file_1 file_2 file_3 ...# 输出除之外的所有行 -v 选项
grep -v "match_pattern" file_name# 使用正则表达式 -E 选项
grep -E "[1-9]+"
egrep "[1-9]+"# 只输出文件中匹配到的部分 -o 选项
grep -o "match_pattern" file_name# 统计文件或者文本中包含匹配字符串的行数 -c 选项
grep -c "text" file_name# 输出包含匹配字符串的行数 -n 选项
grep "text" -n file_name
cat file_name | grep "text" -n
grep "text" -n file_1 file_2# 打印样式匹配所位于的字符或字节偏移
echo gun is not unix | grep -b -o "not"# 搜索多个文件并查找匹配文本在哪些文件中
grep -l "text" file1 file2 file3...# 在多级目录中对文本进行递归搜索
grep "text" . -r -n# 忽略匹配样式中的字符大小写
echo "hello world" | grep -i "HELLO"# 选项 -e 制动多个匹配样式
echo this is a text line | grep -e "is" -e "line" -o#只在目录中所有的.php和.html文件中递归搜索字符"main()"
grep "main()" . -r --include *.{php,html}#在搜索结果中排除所有README文件
grep "main()" . -r --exclude "README"#在搜索结果中排除filelist文件列表里的文件
grep "main()" . -r --exclude-from filelist#不会输出任何信息,如果命令运行成功返回0,失败则返回非0值。一般用于条件测试
grep -q "test" filename#显示匹配某个结果之后的3行,使用 -A 选项:
seq 10 | grep "5" -A 3
5
6
7
8#显示匹配某个结果之前的3行,使用 -B 选项:
seq 10 | grep "5" -B 3
2
3
4
5#显示匹配某个结果的前三行和后三行,使用 -C 选项:
seq 10 | grep "5" -C 3
2
3
4
5
6
7
8#如果匹配结果有多个,会用“--”作为各匹配结果之间的分隔符:
echo -e "a\nb\nc\na\nb\nc" | grep a -A 1
a
b
--
a
b