Linux中grep查找含有某字符串的所有文件

在项目中,经常会遇到批量修改表名或者key/ password的情况。

如果服务器上只有1个项目,我们可以在pycharm中全局搜索,然后替换。但如果服务器上有多个项目,不清楚这些表名/key/ password都在哪些项目中的哪些文件中,一个个打开pycharm查找有些麻烦,还可能会漏掉;所以可以考虑使用grep命令,在服务器上查看需要替换的表名/key/ password都在哪些项目/文件中,然后再打开pycharm进行全局搜索并替换。

 

1、Grep选项:
* : 表示当前目录所有文件,也可以是某个文件名
-r 是递归查找
-n 是显示行号
-R 查找所有文件包含子目录
-i 忽略大小写

2、有意思的命令行参数:
grep -i pattern files :不区分大小写地搜索。默认情况区分大小写
grep -l pattern files :只列出匹配的文件名,不列出路径
grep -L pattern files :列出不匹配的文件名
grep -w pattern files :只匹配整个单词,而不是字符串的一部分(如匹配‘magic’,而不是‘magical’)
grep -C number pattern files :匹配的上下文分别显示[number]行
grep pattern1 | pattern2 files :显示匹配 pattern1 或 pattern2 的行
grep pattern1 files | grep pattern2 :显示既匹配 pattern1 又匹配 pattern2 的行

3、有些用于搜索的特殊符号:
\< 和 \> 分别标注单词的开始与结尾。
例如:
grep man * 会匹配 ‘Batman’、‘manic’、‘man’等
grep '\<man' * 匹配‘manic’和‘man’,但不是‘Batman’
grep '\<man\>' 只匹配‘man’,而不是‘Batman’或‘manic’等其他的字符串。
'^':指匹配的字符串在行首
'$':指匹配的字符串在行尾

 

4、例子:

 1 --递归查找目录下含有该字符串的所有文件
 2 grep -rn "data_chushou_pay_info"  /home/hadoop/nisj/automationDemand/
 3  
 4 --查找当前目录下后缀名过滤的文件
 5 grep -Rn "data_chushou_pay_info" *.py
 6  
 7 --当前目录及设定子目录下的符合条件的文件
 8 grep -Rn "data_chushou_pay_info" /home/hadoop/nisj/automationDemand/ *.py
 9  
10 --结合find命令过滤目录及文件名后缀
11 find /home/hadoop/nisj/automationDemand/ -type f -name '*.py'|xargs grep -n 'data_chushou_pay_info'

 

posted @ 2020-08-18 21:00  一路向北321  阅读(8149)  评论(0编辑  收藏  举报