grep 技巧 12则及注意事项_"grep \"[12]"-程序员宅基地

技术标签: LINUX  

来自http://meifz.blog.163.com/blog/static/4462885820119199295087/

<==使用技巧

1. 多个关键字查找                                                                                           

        1.1 关键字间 or      
        i. 使用-e (--regexp=PATTERN)           
        ii. 使用元字符 \|                                
        iii. 使用-f file

#包含了string.h或者stdlib.h的头文件
i.
grep -l -e 'string\.h' -e 'stdlib\.h' /usr/include/*.h 
ii.
grep 'string\.h\|stdlib\.h' /usr/include/*.h
或者-E 
grep -E 'string\.h|stdlig\.h' /usr/include/*.h
iii.
# cat grepfromfile.txt 
string\.h 
stdlib\.h
grep -f grepfromfile.txt /usr/include/*.h 
       1.2 关键字间 and
        i. 通过管道 |
        ii. 通过正则 
#同时包含'hello','world'的行
i.
echo hello world | grep '\<hello\>' | grep '\<world\>'
ii.(如果包含2个关键字还好,要是n个就有n全排序列种可能!)
grep -E 'hello.*world|world.*hello' /position

2. 单词匹配                                                                                                          

        i. -w(gnu 选项)
        ii. \<\> 
i. 
grep -w 'main' /usr/include/*.h
ii. 
grep '\<main\>' /usr/include/*.h   

3.善用 -E                                                                                                              

 -E选项启用 extended expression,正则写起来更加灵活
#查看gcc帮助文件里两个the/that/and/or连在一起的行
man gcc | grep -E '(\<the\>|\<that\>|\<and\>|\<or\>) \1'
man gcc | grep -E -w '(the|that|and|or) \1'
#查看gcc帮助文件里含两个连续单词的行
man gcc | grep -E -w '([a-zA-Z]+) \1'

4. 忽略大小写 -i                                                                                                    

grep -i 'int_max' /usr/include/limits.h

#匹配连续相同单词
echo 'it IT' | grep -i -w -E '([a-z]+) \1'
echo 'it IT' | grep -E  -w '([a-zA-Z]+) \1'

5. 递归查找 -r(posix 未说明)  (在指定目录中递归查找)                               

#查看日志的错误信息
grep -i -w -r -E 'error|failed|failure' /var/log |less
#只列出包含关键字的文件名
grep -l -r 2222 /etc/sysconfig/*
 

6. 显示匹配行周围行 (posix 未说明)                                                                  

 B/A/C(before/after/context前后)
    -B n
    -A n
    -C n

7. 取反-v                                                                                                              

grep -v -w 'hello' filename

8. 匹配数 -c                                                                                                          

echo aaaa | grep -c 'a'

9. 输出文件名 -l                                                                                                   

grep -l -r -i -w 'filename_max' /usr/include/*.h

10. 只输出匹配部分-o (gnu 选项)                                                                       

grep -o  -f grepfromfile.txt /usr/include/*.h

11. 如果是纯字符串搜索,-F 速度更快。(惟吾无为 12楼补充) 不识别任何元字符!!!

#用gcc manual生成个纯字符串文件作为搜索关键字
        man gcc | tr -cs '[:alpha:]' '\n' >grep.date
        wc -l grep.date
        97288 #这么多!
#比较不带-F,与带-F
 time `man gcc | grep  -F -f grep.date > /dev/null` 
        real        0m0.499s
       user        0m0.741s
       sys        0m0.056s
 time `man gcc | grep   -f grep.date > /dev/null` 
        real        4m9.630s
        user        4m7.602s
        sys        0m0.713s

当纯字符串匹配,尤其是要匹配的字符串非常多,-F不可不用

12. 在查找进程的时候,利用[]实现同时grep -v grep的功能 (xiaopan3322 (扛一肩记忆)  24楼 补充)

 ps -ef | grep "java -jar"  
tdlteman 22023 22006  0 Oct07 ?        00:09:58 java -jar slave.jar
xiabao   31501 30737  0 11:08 pts/8    00:00:00 grep java -jar  
 ###grep 自身也出来了
ps -ef | grep "java -jar" | grep -v grep
tdlteman 22023 22006  0 Oct07 ?        00:09:58 java -jar slave.jar
#grep -v grep 精确结果
ps -ef | grep "[j]ava -jar"
tdlteman 22023 22006  0 Oct07 ?        00:09:58 java -jar slave.jar

<==注意事项                                                                                                        

1. [a-d] 与 [abcd] 不一定等价 (mpstat (卢瑟) 补充,34楼)
正则表达式中出现range[]是里面的序列是受字符集和环境变量影响的。典型的,许多 locale 将字符以字典顺序排序,在这些 locale 中, [a-d] 不与 [abcd] 等价;例如它可能与 [aBbCcDd] 等价
为了提高可移植性:
        1. 使用POSIX定义的字符组
        2. 定义环境变量LC_ALL
2. 匹配 - 开头的关键字 如(--shit)grep出错 (mpstat (卢瑟) 补充,34楼)
         如果关键字以-开头,会打乱grep对选项的解析
        解决:
        使用 -e选项 或 --
        [iscs@linux-sp1]:/users/iscs>$ echo "--shit"|grep --shit
        grep: unrecognized option '--shit'
        Usage: grep [OPTION]... PATTERN [FILE]...
        Try `grep --help' for more information.
        [iscs@linux-sp1]:/users/iscs>$ echo "--shit"|grep -- --shit
        --shit
        [test@test~]$ echo '--shit' | grep -e '--shit'
        --shit
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/after_s/article/details/8058100

智能推荐

STM32接GSM模块(只用TX RX)_32板子上连接gsm模块的串口是哪个-程序员宅基地

文章浏览阅读5.5k次,点赞2次,收藏9次。这几天尝试了下STM32的USART3去接gsm模块。整了好久没整出来,甚是纠结。途中遇到两个问题:1.USART3配置问题 2.接线问题USART3也是重映射到PC10 PC11这两个口的,所以要有GPIO_PinRemapConfig(GPIO_PartialRemap_USART3, ENABLE);其实最主要的问题就是接线问题,即模块电压和MCU电压不一样。我的GSM模块_32板子上连接gsm模块的串口是哪个

阅读笔记-HTTP返回状态码-程序员宅基地

文章浏览阅读124次。HTTP返回状态码1 HTTP超文本协议HTTP是基于客户端/服务端(C/S)的框架模型,通过一个可靠的链接来交换信息,是一个无状态的请求/响应协议。一个HTTP“客户端”是一个应用程序(Web浏览器或其他任何客户端),通过连接到服务器达到向服务器发送一个或多个HTTP请求的目的。一个HTTP“服务器”同样也是一个应用程序(通常是一个Web服务,如Apache Web服务器或IIS服务器..._nginx 请求头太大(nginx) nginx 内置代码和 431 类似。

算法:堆排序之每次输入插一次堆&输入完成后建堆_堆排序的过程中,每次进行堆调整后,打印输出堆的次序-程序员宅基地

文章浏览阅读576次。1./*Name:插入堆排序(A[0]为空情况)Coder:Lou JianghuiTime:22:49-23:07*/#include#include#includeusing namespace std;int A[1000];int n;void print(int n){ for (int i = 1;_堆排序的过程中,每次进行堆调整后,打印输出堆的次序

【HLL】使用 HyperLogLog 去重案例_hyperloglog可以处理带重复元素的流数据吗-程序员宅基地

文章浏览阅读695次。1.概述HyperLogLog一个常用的场景就是统计网站的UV。##基数 简单来说,基数(cardinality,也译作势),是指一个集合(这里的集合允许存在重复元素)中不同元素的个数。例如看下面的集合: {1,2,3,4,5,2,3,9,7} 这个集合有9个元素,但是2和3各出现了两次,因此不重复的元素为1,2,3,4,5,9,7,所以这个集合的基数是7。maven <dependency> <groupId>net.agkn</grou._hyperloglog可以处理带重复元素的流数据吗

Navicat模型中的表展示注释的方法_navicat在表对象界面显示表的备注-程序员宅基地

文章浏览阅读1.2w次,点赞3次,收藏8次。先展示下效果图:Navicat不能直接将注释展示在表模型上,需要曲线救国。展示表的中文名方法:选中画布上的一个表模型,然后在左侧的图表页签中将“显示描述”勾选中,表模型上方会自动出现一个描述框,选中描述框右键选择编辑,填写表的中文名即可。展示表字段对应的中文名的方法:选择左侧的新建笔记,然后右键选中笔记,选择样式为标签,对应表字段顺序输入中文名称,最后将标签调整到适当位置即可。标签的样式也可以通过左侧属性配置进行修改,比如间距,字体大小之类。..._navicat在表对象界面显示表的备注

推导部分和【蓝桥杯国赛】_推导部分和 带权并查集 蓝桥-程序员宅基地

文章浏览阅读141次。对于一个长度为N的整数数列A1​A2​⋯AN​,小蓝想知道下标l到r的部分和il∑r​Ai​Al​Al1​⋯Ar​是多少?然而,小蓝并不知道数列中每个数的值是多少,他只知道它的M个部分和的值。其中第i个部分和是下标li​到ri​的部分和∑jli​ri​​Ali​​Ali​1​⋯Ari​​, 值是Si​。_推导部分和 带权并查集 蓝桥

随便推点

spring数据源配置:Tomcat/weblogic数据源切换配置_tomcat 数据库切换-程序员宅基地

文章浏览阅读1.4k次。数据配置方式一般是三种:1.org.springframework.jdbc.datasource.DriverManagerDataSource(没有池概念,有连接就建立一个connection)2.org.apache.commons.dbcp.BasicDataSource(连接池技术)3.org.springframework.jndi.JndiObjectFactoryBea..._tomcat 数据库切换

计算机组成原理 之 计算题、分析题 题解详细总结(已完结)_计算机组成原理计算题-程序员宅基地

文章浏览阅读1.7w次,点赞62次,收藏544次。第1章 计算机系统概述0、1编码第2章 存储系统磁盘存储器第6章 控制器逻辑Intel 8086 指令简介第1章 计算机系统概述0、1编码1、分别求出+1111B和-1001B的真值及其机器数的原码、反码、补码形式。答案:+1111B的真值:15原码01111 反码01111 补码01111-1001B 的真值:-9原码11001 反码10110 补码10111另一种写法:解: +1111B 真值:15D [x]原=01111B [x]反=01111B [x]补=011._计算机组成原理计算题

react-native 0.57 版本更新日志-程序员宅基地

文章浏览阅读647次。[0.57]欢迎来到React Native版本的0.57版!这个版本解决了许多问题,并有一些令人兴奋的改进。我们再次跳过了一个月发布,通过扩展发布候选阶段关注质量,并且兼容之前的版本这个版本包括599提交由73个不同的贡献者!为了响应反馈,我们准备了一个只包含用户影响的更改的变更日志。请分享您的意见,并让我们知道我们如何使这更有用,如果您对此有任何反馈,和往常一样请告知我们let us kn..._react-native 0.57版本文档

【IDEA&Eclipse快捷键对照表】_eclipse的folder对应idea的哪个-程序员宅基地

文章浏览阅读4.6k次,点赞8次,收藏44次。IDEA Comment Eclipse Comment Remark Ctrl+Alt+H 调用层次 Ctrl+Alt+H 开放的调用层次结构 Ctrl+E 展示打开的文件(快速转换编辑器) Alt+7 当前文件结构 Ctrl+O 当前文件结构 Ctrl+H 查看Java类层次结构 Ctrl+....._eclipse的folder对应idea的哪个

修改pycharm目录后,无法打开的问题!!!_为什么修改已安装的pycharm的安装路径会打不开软件-程序员宅基地

文章浏览阅读2.1k次。最近因为一些操作,想将命名不规范的pycharm安装目录的空格删掉,但是删掉以后,发现pycharm怎么也打不开了。在将脑汁都绞尽以后,参考一篇博客,终于发现了问题所在https://blog.csdn.net/weixin_45696455/article/details/106414316在看了上面一篇博客后,谢谢哥,茅塞顿开,原来是我破解的.vmoption文件问题,里面写了破解包路径,一旦修改pycharm路径后,将无法找到该破解包。但当我在文件夹打开.vmoption文件以后,发现我并没有写破_为什么修改已安装的pycharm的安装路径会打不开软件

labview中visa插件安装教程_nivisa安装教程-程序员宅基地

文章浏览阅读2.2w次,点赞7次,收藏29次。1.在NI官网下载VISA,上一篇文章中已经讲到,此处不再赘述。2.关到电脑的所有杀毒软件,非常重要。3.点击运行。4.一直点击next,在需要更改安装目录时,自己更改(最好不要安装在C盘)。5.安装结束后,在最新安装目录下查找NI-MAX。可以直接将他拖动到桌面即可。打开后查看设备与接口若发现里面含有内容,则安装成功,如下图所示。..._nivisa安装教程

推荐文章

热门文章

相关标签