grep的用法,小技巧,模板中含有\t时:grep |
您所在的位置:网站首页 › with的用法小技巧 › grep的用法,小技巧,模板中含有\t时:grep |
这个--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:12343: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
find 与 grep 的区别 find命令 find命令.这个命令对于我们用来查找文件时是相当有用的,但是对于Linux新手来说却有一些难于使用,在一定程序是由于他所带的选项,测试,动作类型参数,而且一个参数的执行结果会影响接下来的参数. 在我们深入这些选项和参数之前,我们先来看一个非常简单的例子.假如在我们的机子上有一个文件wish.我们来进行这个操作时要以root身份来运行,这样就可以保证我们可以搜索整个机子: grep命令 grep命令,这是一个并不常见的名字,他是通用正则表达式解析器的简称(General Regular Expression Parser).我们使用find命令在我们的系统是查找所需的文件,但是我们却要使用grep命令在文件中查找指定的字符串.而事实上,最常用的做法就是当我们在使用find命令时将grep作为一个命令传递给-exec. 简单的说: find :搜索磁盘中的文件名 grep: 搜索出现关键字的文件 Linux find和grep的区别 1.find:查找文件或目录 语法: find 查找位置 文件名或目录名 如:在 /root/luojiahui目录下查找index.htm find /root/luojiahui index.htm 在当前目录及其子目录中查找任何扩展名为"c"的文件(不加-print也会输出结果) find . -name "*.c" find bootable kernel -name "*.c" 2.grep:在文件中查找字符串 语法:grep 字符串 文件名 如:grep success luojiahui.txt 在文件luojiahui.txt查找success grep -r "待查字符串" * grep -r dump_info /home/zhenwx/kernel
Grep的若干小技巧 匹配不符合模式的字符串 grep -v "pattern" file 模板中含有\t grep -P "^\t" file 两文件差集(B.txt-A.txt) grep -F -v -f A.txt B.txt 用A.txt文件中的词表查B.txt grep -f A.txt B.txt 与Pipe配合 cat B.txt | grep -f A.txt还有 cat A.txt | grep -f - B.txt 参考 Drew’s grep tutorialLINUX Shell下求两个文件交集和差集的办法How to grep with a list of words
|
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |