欢迎各位兄弟 发布技术文章
这里的技术是共享的
1.正则表达式
链接自http://blog.sina.com.cn/s/blog_691a84f301015khx.html
来自 http://blog.csdn.net/duguduchong/article/details/7716908
Linux下查找含有某字符串的文件的方法:
grep "John" /usr/include -r
其中"John"是你要查找的内容,可以使用通配符和转义字符。
/usr/include是你要搜索的目录
-r是所在的一个参数,是可选的(optional),r表示recursive
来自 http://www.linuxidc.com/Linux/2011-12/49529.htm
版权声明:本文为博主原创文章,未经博主允许不得转载。
进入要查找文件所在的文件夾
简便的方法直接输入命令
grep -rn "aa" *.c
一、直接使用命令行(推荐使用)—— xarge 替代 -exec
find . -name /*.c -print | xargs grep "*****"
*.c:指只查找扩展名为 .c 的文件
"*":为要查找的字符串
二、定义shell脚本使用(不推荐使用)——使用 -exec
传建文件 a.sh
#!/bin/bash
grep "from fd" $1
if [ $? -eq 0 ]
then
echo $1
fi
执行命令
find . -name /*.c -exec ./a.sh {} /;
调用find使用-exec来运行一个命令,他将为处理的每个文件执行一次命令,命令的每次执行都会创建一个新的进程,处理大量文件时将导致系统文件枯竭,所以第二种方法不推荐使用。
来自 http://blog.csdn.net/dreamcode/article/details/4128911
转自:http://151wqooo.blog.51cto.com/2610898/1162118
如果你想在当前目录下 查找"hello,world!"字符串,可以这样:
grep -rn "hello,world!" *
* : 表示当前目录所有文件,也可以是某个文件名
-r 是递归查找
-n 是显示行号
-R 查找所有文件包含子目录
-i 忽略大小写
下面是一些有意思的命令行参数:
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 的行。
这里还有些用于搜索的特殊符号:
\< 和 \> 分别标注单词的开始与结尾。
例如:
grep man * 会匹配 ‘Batman’、‘manic’、‘man’等,
grep '\<man' * 匹配‘manic’和‘man’,但不是‘Batman’,
grep '\<man\>' 只匹配‘man’,而不是‘Batman’或‘manic’等其他的字符串。
'^':指匹配的字符串在行首,
'$':指匹配的字符串在行尾,
2,xargs配合grep查找
find -type f -name '*.php'|xargs grep 'GroupRecord'