每天一命令之grep

来自linux中国网wiki
跳到导航 跳到搜索

常用参数

#多个and 
ps -ef | grep  -E 'tomcat1 |tomcat2 |grep -v grep '



 grep -E 'dd|77' file
dd
77
[root@evantestvm ~]# cat file
dd
ee
44
66
77





grep -rn   sth  somefiles #比dat 好

##并  fstab 文件中 有  /data  和 UUID 关键词
grep  /data /etc/fstab | grep UUID 


grep 同时满足多个关键字和满足任意关键字
① grep -E "word1|word2|word3"   file.txt
   满足任意条件(word1、word2和word3之一)将匹配。
② grep word1 file.txt | grep word2 |grep word3  试了好像不行 
   必须同时满足三个条件(word1、word2和word3)才匹配。


  -r, --recursive           等同于--directories=recurse
   -i, --ignore-case         在模式和数据中忽略大小写 不区分大小写
  -n, --line-number         输出的同时打印行号
   -v: --invert-match 反转          显示没有匹配的行。 反选 




find & grep 总结

精准 非贪婪匹配

 -w, --word-regexp         强制 PATTERN 仅完全匹配字词
              Select  only  those  lines containing matches that form whole words.  The test is that the matching substring must either be at the beginning of the line, or preceded by a
              non-word constituent character.  Similarly, it must be either at the end of the line or followed by a non-word  constituent  character.   Word-constituent  characters  are
              letters, digits, and the underscore.  This option has no effect if -x is also specified.



grep "but container not found" application* | grep -oP 'asnId: \K\d+(?= )' | sort --unique

第一个grep过滤出所有符合要求的行,第二个grep用regex格式得到匹配组,sort可以保证输出的匹配值是唯一的。至于\K还有( ?=)的意思可以参考这里:https://unix.stackexchange.com/questions/13466/can-grep-output-only-specified-groupings-that-match

原文链接:https://blog.csdn.net/weixin_42325834/article/details/110254058





过滤注释和空行

cat  /etc/zabbix/zabbix_agentd.conf | grep  -v \^# |  grep -v \^$

see also

grep 参数使用和实例


Linux: grep多个关键字“与”和“或”


Linux/Unix下grep命令使用的几个例子[grep Examples]