Linux grep 命令用于查找文件里符合条件的字符串
grep 指令用于查找内容包含指定的范本样式的文件,如果发现某文件的内容符合所指定的范本样式,预设 grep 指令会把含有范本样式的那一列显示出来。若不指定任何文件名称,或是所给予的文件名为 -
,则 grep 指令会从标准输入设备读取数据。
grep -rn "iMisty!" *
查找当前目录下包含iMisty!
关键字的文件以及所在行
*
表示当前目录所有文件,也可以是某个文件名
-r
递归查找
-n
是显示行号
-R
查找所有文件包含子目录
-i
忽略大小写
grep -i pattern files
:不区分大小写地搜索。默认情况区分大小写,
grep -l pattern files
:只列出匹配的文件名,
grep -L pattern files
:列出不匹配的文件名,
grep -v 或 --revert-match pattern file:
显示不包含匹配文本的所有行。
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
等其他的字符串。
^
:指匹配的字符串在行首,
$
:指匹配的字符串在行尾
相关命令
find . | xargs grep -ri 'api'