R的意思是递归的对目录下的所有文件(包括子目录)进行 grep。

比如 grep -R main src就会搜索src目录下所有文件中是否包含 main 这个字符串。

因此grep -R "main" *.c 中的 -R 是没有意义的,因为你输入参数是 *.c 而不是目录名字。

xargs cmd 将标准输入输入的每一项作为参数执行一次cmd,

因此find . -name "*.c" | xargs grep main就是将find找到的每一个文件的名字用 grep main 来执行一下,

比如find找到了a.c b.ct est.c那么xargs就将执行三次grep main,分别为grep main a.cgrep main b.cgrep main test.c

最后的一个问题,你可以,用 -R,但是注意单纯的-R会对目录下每一个文件都执行,

通过find则可以只对find到的文件执行。但是如果你的grep版本够新,可能会支持 --include=xxx 的输入参数,

就可以这样来grep -R --include=*.c main dir就会搜索dir及其自目录下所有 .c文件中是否有main,其他文件都不会搜索了。

来自:http://zhidao.baidu.com/question/146286902.html&__bd_tkn__=6ca21120346993344f0aa0578dbe36ae8f01dff58078338d51fed8133ea5c69d362ad36bb4bcda3b39bb3949f6bbe47087ac3af56e60b1f4e7eb60157958fb309561a0f85c0f03de0125270ed036b80b3f769b75795abf8ea238330c735d3a5ccb177e3a41b6afde9f0efcaccbdc8c0acd3c23fe46af

一些补充:

这个--include选项, 可以这样使用:
grep -rn --include='*.c' --include='*.h' re .

可以指定多次, 如果真是上面的这种情况,  其实可以用
grep -rn --include='*.[ch]' re .

但是, 如果源文件中含有C++源代码, 上面的方法就不凑效了, 因为[]中只能放一个字符.
grep -rn --include='*.{cpp,h}' 也是不行的.
此时需要不加引号的展开(由bash执行grep之前就已经完成, 可以通过set -x观察)

grep -rn --include=*.{cpp,h} re .

bash中对{A,B}这种形式的展开, 会忽略是否在当前目录下存在相应的文件. 这样的写法, 可以避免手指累残在命令行上.


高亮显示

grep --color=auto 'pattern'   'text'

echo -e '\e[34mhaha\e[m'  这样会输出带颜色的字符串 -e 表示特殊处理 \e 这个 \e必须跟着 [符号

grep 常用

grep [-acinv] '搜寻字符串' filename

参数说明:

-a :将 binary 档案以 text 档案的方式搜寻数据

-c :计算找到 '搜寻字符串' 的次数

-i :忽略大小写的不同,所以大小写视为相同

-n :顺便输出行号

-v :反向选择,亦即显示出没有 '搜寻字符串' 内容的那一行!

1.搜索特定的字符

grep 'oo' pp.txt  以下仅仅用 pp 代表 pp.txt

查看显示字符的行数

grep -n 'oo' pp

查看非oo的字符

grep -v 'oo' pp

查看大小写忽略的字符

grep -i 'oo' p

2.利用[]处理搜索结果

查看 tast 和 test的字符串

grep -n 't[ae]st' pp  这里[ae]只当一个字符处理 a 或者是 e 这样就能匹配 上面的要求

若是希望匹配 t(x)st 这个x是任意的字符的话,那么可以如下处理方式

grep 't[.]st' pp  .符号代表任意的字符

查看包含oo字符的信息

grep -n 'oo' pp

若是希望在oo之前没有g的字符信息

grep -n '[^g]oo' pp 这里的^就是取反的意思 非goo得字符

取前面非字符的字符

grep -n '[^a-zA-Z]oo' pp

得到数字的字符的话

grep -n '[0-9]' pp  // 其实这个等同于  grep -n '[0-9[0-9]*' pp * 代表0个或是多个重复的信息

3.行首和行尾的特殊处理 $^

若是希望取得第一行是 the 开头的字符行

grep -n '^the' pp

若是希望取得以英文字符开头的字符

grep -n '^[a-zA-Z]' pp

取得不是以英文字符开头的信息

grep -n '^[^a-zA-Z]' pp   // 里面的^是取反 外面的^是以上面开头

取得小数点结尾的行

grep -n '\.$' pp     //小数点是特殊字符 需要用\进行转义

注意在windows下 换行时 ^M 这个符号

取得一个空行的方式

grep -n '^$' pp 这里就是取空行了

希望取得所有文档中非注释掉得内容的话 那么可如下

grep -v '^$' pp|grep -v ^#              第一个是取非空行的数据 第一个管道是取非#开头的数据

我像有时候更多的是取 #开头的行

grep -n '^#' pp

4.任意字符和重复字符

. :绝对的任意字符

* :0个或是多个相同字符

要查看gf中间是两个字符的数据

grep -n 'g..f' pp

至少有一个是o的字符串

grep -n 'oo*' pp  //因为*代表0个或是多个

以g开头和结尾,中间至少一个o

grep -n 'goo*g'

查找gg中间是任意字符的字符串

grep -n 'g.*g' pp 这里.就代表任意字符

5.限定符 {}

查看g和p之间存在两个连个o的字符串

grep -n 'go\{2,5\}p'

查找至少两个的字符创

grep -n 'go\{2,\}p' pp

查找只有两个的字符串

grep -n 'go\{2\}p' pp

6.重要的特殊字符

^word待搜寻的字符串(word)在行首!

范例:grep -n '^#' pp 搜寻行首为 # 开始的那一行!

word$待搜寻的字符串(word)在行尾!

范例:grep -n '!$' pp 将行尾为 ! 的那一行打印出来!

.代表任意的一个字符

范例; grep -n 'g.' pp 将是g开头的两个字符打印出来

\将特殊字符转义

范例:grep -n \' pp  搜索有单引号的那一行

*:匹配0个或是多个字符

grep -n 'o*' pp 匹配拥有零个或是多个o的字符

\{n,m\} :匹配的个数

grep -n 'o\{2\}' pp 打印出拥有两个oo的字符

[]匹配单个字符

1.[list] : [abl] 匹配 abl中任意一个

2.[^xx]:对其中的字符进行取反  这里只能对的那个字符进行取反 若是希望是多个字符取反的话 还需要看看

3.[char1-char2]:匹配某个范围之内的数据 例如 [a-z][A-Z][0-9]

7.扩张的grep --- > egrep  这个等同于 grep -E

grep -v '^$' pp | grep -v '^#'

通过egrep来表示就是

egrep -v '^$|^'

8.查找内容有“或”的关系:

#查找数字为23或24的内容,并显示内容与行号

grep -E '23|24' * -n

9.查找data.txt文件有多少个空行:

grep '^$' data.txt -c

10.查询当前目录中还有多少个目录:

ls -l | grep '^d'

11.查找data.txt文件字符串尾部为a的内容

grep 'a$' data.txt -i -n

$ grep "sort it" *      (#或在所有文件中查询单词“sort it”)

接下来的所有示例是指在单个文件中进行查询
 行匹配
$ grep -c "48" data.f
$ 4                      (#g r e p返回数字4,意义是有4行包含字符串“4 8”。)
$ grep "48" data.f          (#显示包含“4 8”字符串的4行文本)

显示满足匹配模式的所有行行数:
[root@mypc oid2000]# grep -n 1234 111.txt 
1:1234
3:1234ab

6. 精确匹配
[root@mypc oid2000]# grep "1234\>" 111.txt 
1234

7. 查询空行,查询以某个条件开头或者结尾的行。
结合使用^和$可查询空行。使用- n参数显示实际行数
[root@mypc oid2000]# grep -n "^$" 111.txt    (返回结果 2:   #说明第二行是空行)
[root@mypc oid2000]# grep -n "^abc" 111.txt (#查询以abc开头的行)
[root@mypc oid2000]# grep -n "abc$" 111.txt (#查询以abc结尾的行)

8. 匹配特殊字符,查询有特殊含义的字符,诸如$ . ' " * [] ^ | \ + ? ,必须在特定字符前加\。
[root@mypc oid2000]# grep "\." 111.txt (#在111.txt中查询包含“.”的所有行)
[root@mypc oid2000]# grep "my\.conf" 111.txt (#查询有文件名my. c o n f的行)

9. 目录的查询
[root@mypc oid2000]# ls –l |grep “^d”   (#如果要查询目录列表中的目录)
[root@mypc oid2000]# ls –l |grep “^d[d]” (#在一个目录中查询不包含目录的所有文件)
[root@mypc]# ls –l |grep “^d…..x..x” (#查询其他用户和用户组成员有可执行权限的目录集合)

10.排除自身

ps -ef|grep telnet | grep -v grep (在显示的进程中抽出“telnet”进程;并丢弃ps中的grep进程)

egrep的几个特殊字符

+ :至少一个或是多个   egrep -n 'go+d' pp

?:0个或是一个        egrep -n 'go?d' pp

| :用或的方式来查找   egrep -n 'go|good' pp 查找go或是good

():找出群组的数据      egrep -n 'g(o|pp)d' pp 查看god 或是gppd  这个类似于 [] 但是比[]强大的是可以是多个字符进行乱换

egrep -n 'd(r|o)e' pp  ===== grep -n 'd[ro]e' pp

来自:http://www.cnblogs.com/wangkangluo1/archive/2012/04/18/2454959.html

(转载)grep的使用的更多相关文章

  1. [转载]grep查看上下文及简单正则表达式

    转载自:https://www.cnblogs.com/mfryf/p/3336288.html inux grep 显示前后几行的信息2016年03月02日 14:10:58 ChenHui246 ...

  2. 【转载】Linux中强大且常用命令:find、grep

    转载自:http://www.linuxeden.com/html/softuse/20130804/142065.html 在linux下面工作,有些命令能够大大提高效率.本文就向大家介绍find. ...

  3. 【转载】grep,egrep,fgrep详解

    [转载自]http://blog.csdn.net/homking/article/details/6000711 egrep 等价于 grep -E fgrep 等价于 grep -F grep - ...

  4. ps 和 grep 查找消除 grep自身查找(转载)

    用ps -def | grep查找进程很方便,最后一行总是会grep自己. $ ps -def | grep dragonfly-framework dean 5273 5272 0 15:23 pt ...

  5. [Linux]正则表达式和grep使用【转载】

    [Linux]正则表达式和grep使用 2018年12月05日 23:45:54 祥知道 阅读数 78 标签: 正则表达式grepLinuxegrep 更多 个人分类: Linux 所属专栏:  Li ...

  6. liunx 的 grep命令(转载)

    简介 grep (global search regular expression(RE) and print out the line,全面搜索正则表达式并把行打印出来)是一种强大的文本搜索工具,它 ...

  7. grep在指定类型的文件中查找字符 (转载)

    转自:http://blog.csdn.net/qvbfndcwy/article/details/8127329 find -name '*.php'|xargs grep 'include'//在 ...

  8. 用grep在子目录中指定的文件类型中查找(转载)

    转自:http://www.ai7.org/wp/html/653.html grep -r abcd *.py 这样的命令得不到你期待的结果,而 grep -r abcd * 这样得到的结果又太多, ...

  9. 在CentOS 7/6.5/6.4 中安装Java JDK 8(转载)

    转载在CentOS 7/6.5/6.4 中安装Java JDK 8 首先,在你的服务器上运行一下更新. yum update 然后,在您的系统上搜索,任何版本的已安装的JDK组件. rpm -qa | ...

随机推荐

  1. [C/C++] extern关键字详解以及与static、const区别

    extern用法详解: 1. 声明外部实体 声明外部全局变量或对象,一般用于头文件中,表示在其它编译单元内定义的变量,链接时进行外部链接,如: extern int ivalue; 此时的extern ...

  2. 【题解】[WC2006]水管局长

    感觉这题好强啊……本来以为能过,结果毫无疑问的被ge了一顿……在这里记录一下做的过程,也免得以后又忘记啦. 首先,我们应看出在这张图上,要让经过的水管最长的最短,就是要维护一棵动态的最小生成树.只是删 ...

  3. [LOJ#6437][BZOJ5373]「PKUSC2018」PKUSC

    [LOJ#6437][BZOJ5373]「PKUSC2018」PKUSC 试题描述 九条可怜是一个爱玩游戏的女孩子. 最近她在玩一个无双割草类的游戏,平面上有 \(n\) 个敌人,每一个敌人的坐标为 ...

  4. Android逆向之旅---爆破一款资讯类应用「最右」防抓包策略原理分析

    一.逆向分析 首先感谢王同学提供的样本,因为王同学那天找到我咨询我说有一个应用Fiddler抓包失败,其实对于这类问题,我一般都会这么回答:第一你是否安装Fiddler证书了,他说他安装了.第二你是否 ...

  5. AOJ.502 不只是水仙花

    不只是水仙花 Time Limit: 1000 ms Case Time Limit: 1000 ms Memory Limit: 64 MB Total Submission: 1196 Submi ...

  6. 从零开始学习MXnet(五)MXnet的黑科技之显存节省大法

    写完发现名字有点拗口..- -# 大家在做deep learning的时候,应该都遇到过显存不够用,然后不得不去痛苦的减去batchszie,或者砍自己的网络结构呢? 最后跑出来的效果不尽如人意,总觉 ...

  7. [洛谷P2073] 送花

    送花 题目背景 小明准备给小红送一束花,以表达他对小红的爱意.他在花店看中了一些花,准备用它们包成花束. 题目描述 这些花都很漂亮,每朵花有一个美丽值W,价格为C. 小明一开始有一个空的花束,他不断地 ...

  8. [bzoj 1143]最长反链二分图最大匹配

    Dilworth定理:偏序集能划分成的最少的全序集的个数与最大反链的元素个数相等. 证明:http://www.cnblogs.com/itlqs/p/6636222.html 题目让求的是最大反链的 ...

  9. 学习正则表达式及c#应用

    1.0正则表达式语法   正则表达式是一种文本模式,包括普通字符(例如,a 到 z 之间的字母)和特殊字符(称为“元字符”).模式描述在搜索文本时要匹配的一个或多个字符串. 正则表达式示例   表达式 ...

  10. [洛谷P2127] 序列排序

    洛谷题目链接:序列排序 题目描述 小C有一个N个数的整数序列,这个序列的中的数两两不同.小C每次可以交换序列中的任意两个数,代价为这两个数之和.小C希望将整个序列升序排序,问小C需要的最小代价是多少? ...