语法:grep 选项 ‘word’ filename -c:打印符合要求的行数 -i:不区分大小写 -n:在输出符合要求的行的同时显示行号 -v:打印不符合要求的行 -A:后跟一个数字n,表示打印符合要求的行以及下面n行 -B:后跟一个数字n,表示打印符合要求的行以及上面n行 -C:后跟一个数字n,表示打印符合要求的行以及上下各n行 -r:会把目录下所有的文件全部遍历 --color:把匹配到的关键词用红色标示 例子:

  1. 过滤出带有某个关键词的行并输出行号 grep -n ‘root’ 1.txt
  2. 过滤出不带有某个关键词的行并输出行号 grep -nv ‘root’ 1.txt
  3. 过滤出所有包含数字的行 grep '[0-9]' 1.txt
  4. 过滤出所有不包含数字的行 grep -v '[0-9]' 1.txt
  5. 去除所有以#开头的行 grep -v '^#' 1.txt
  6. 去除所有空行和以#开头的行 grep -v '^$' 1.txt|grep -v '^#'
  7. 过滤出以英文字母开头的行 grep '^[a-zA-Z]' 1.txt
  8. 过滤出以非数字开头的行 grep -v '^[0-9]' 1.txt或者grep '^[^0-9]' 1.txt
  9. 过滤任意一个或多个字符 grep 'r.o' 1.txt;grep 'r*t' 1.txt ;grep 'r.*t' 1.txt
  10. 过滤出包含root的行以及下面一行 grep -A1 'root' 1.txt
  11. 过滤出包含root的行以及上面一行 grep -B1 'root' 1.txt
  12. 指定过滤字符次数 grep 'o{2}' 1.txt
  13. 把一个目录下,过滤所有*.php文档中含有eval的行 grep -r --include="*.php" 'eval' /data/
  14. 过滤两个或多个关键词 grep -E '123|abc' filename #找出文件中包含123或者abc的行 或者egrep '123|abc' filename 或者awk '/123|abc/' filename

egrep=grep -E

  1. 匹配1个或者1个以上+前面的字符 egrep 'o+' 1.txt
  2. 匹配0个或者1个?前面的字符 egrep 'o?' 1.txt
  3. 匹配roo或者匹配body egrep 'roo|body' 1.txt
  4. 用括号表示一个整体,下面例子会匹配roo或者ato egrep 'r(oo)|(at)o' 1.txt
  5. 匹配1个或者多个oo egrep '(oo)+' 1.txt

.:表示任意一个字符 :表示0个或多个前面的字符 +:表示1个或多个+前面的字符 ?:表示0个或1个?前面的字符 .*:表示任意个任意字符(包含空行) 注意:+和?grep不支持,egrep才支持。