grep使用总结

grep使用总结

    • 1. 常用命令选项
    • 2. 特殊使用场景

1. 常用命令选项

  • -i
grep -i "string" FILE #关键词忽略大小写
  • -A
grep 'string' -A3 FILE #after, 同时打印命中行后面指定的行
  • -B
grep 'string' -B3 FILE #before, 同时打印命中行前面指定的行
  • -C
grep 'string' -C3 FILE #命中的行前后各3行, 相当于-A3 -B3
  • -E
grep -E "vmx|svm" /proc/cpuinfo #同时使用扩展的正则
  • -e
 grep -e 'quartz' -e 'snap' pom.xml #多个pattern满足其中之一即可
  • -F
grep -F 'A*' #不使用正则表达式,fgrep比grep命令快, 它只能找固定的文本,而不是规则表达式
  • -n
grep -n "go" demo_text #打印行数, 得到行数后可以结合sed一起使用
  • -l
grep -l 'quartz' *.xml #只显示内容命中关键字的文件名称,而不显示具体匹配的内容
  • -L
grep -l 'quartz' *.xml #只显示内容没有命中关键词的文件名称,而不显示具体匹配的内容
  • -m
grep -m5 'quartz'  pom.xml #命中多少行后不再读取文件
  • -c
grep -c "pattern" filename #计算出命中匹配的**总行数**
  • -v
grep -v "go" demo_text  # 显示哪些不包含 go 子串的行
  • -r
grep -r "ramesh" * #使用 -r 参数来实现递归的搜索目录
  • -w
grep -iw "is" demo_file #匹配完整的单词,而不是子串, 只会完整的匹配is这个单词

2. 特殊使用场景

  • 多文件搜索

文件名用wizard通配符(包含*和?)

grep "string" *.log
  • 搜索关键词使用正则
grep "REGEX" filename #正则天然支持
  • 命中多个关键词任意一个
grep -e "pattern1" -e "pattern2" filename # 显示符合pattern1和pattern2的结果的数据
  • 同时不满足所有关键字
grep -v -e "pattern1" -e "pattern2" filename # 显示不符合pattern1和pattern2的结果的数据

你可能感兴趣的:(Shell,linux,grep)