Linux三剑客之老三grep
说明:
Linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来。工作中我们常常用它来过滤出我们想要的数据。
格式:
grep [OPTIONS]
基本参数:
-i 不区分大小写
-v 排除内容,即取反
-n 对匹配到的内容打印相应行号
-E 使用扩展正则表达式(相当于egrep)
-r 递归读取目录下的文件(即包括子目录下文件)
-c 对匹配到的行进行计数
-o 只显示匹配到的内容
-A (after)匹配输出内容行并输出内容行后的指定行
-B (before)匹配输出内容行并输出内容行前的指定行
-C (context)匹配输出内容行并输出内容行的前后指定行
--color 过滤的内容显示颜色
建议配置别名:
echo “alias grep='grep --color'” >> /etc/profile //配置别名
source /etc/profile //重读文件使别名生效
效果:
[root@vm1 test]# grep ".*" /etc/passwd root:x:0:0:root:/root:/bin/bash bin:x:1:1:bin:/bin:/sbin/nologin daemon:x:2:2:daemon:/sbin:/sbin/nologin
常见用法:
① grep -ivnEoc… “匹配内容” 文件名
[root@vm1 test]# grep -n "root" /etc/passwd 1:root:x:0:0:root:/root:/bin/bash 11:operator:x:11:0:operator:/root:/sbin/nologin
② grep -r “匹配内容” 文件目录/*
[root@vm1 ~]# grep -r "www" test/* test/Caiyun.txt:My blog is http://www.cnblogs.com/Caiyundo/ test/dudu/3.txt:www.cnblog.com/caiyun
③ grep “匹配内容” -A 指定行 文件名
[root@vm1 ~]# grep "root:x" -nA 5 /etc/passwd 1:root:x:0:0:root:/root:/bin/bash 2-bin:x:1:1:bin:/bin:/sbin/nologin 3-daemon:x:2:2:daemon:/sbin:/sbin/nologin 4-adm:x:3:4:adm:/var/adm:/sbin/nologin 5-lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin 6-sync:x:5:0:sync:/sbin:/bin/sync
④ 命令 | grep “匹配内容”
[root@vm1 ~]# ps -ef |grep "sshd" root 1261 1 0 Dec12 ? 00:00:00 /usr/sbin/sshd
扩展:
正则表达式是为处理大量字符串而定义的一套规则和方法,linux正则表达式常用于linux三剑客中。
测试场景模拟(直接复制粘贴即可):
cat >>text.txt<<EOF
My name is Caiyun.
I like badminton, snooker, running
Maybe I'm not a smart person, but I'm working hard.
My blog is http://www.cnblogs.com/Caiyundo/
Welcome to my blog! CAIYUN
My qq is 791111890
My mail is Caiyun111111@gmail.com.
EOF
一、 基础正则表达式
^ 表示以...字符开头,^word
[root@vm1 test]# grep -n "^My" text.txt 1:My name is Caiyun. 5:My blog is http://www.cnblogs.com/Caiyundo/ 8:My qq is 791111890 9:My mail is Caiyun111111@gmail.com.
$ 表示以...字符结尾,word$
[root@vm1 test]# grep -n "\.$" text.txt 1:My name is Caiyun. 4:Maybe I'm not a smart person, but I'm working hard. 9:My mail is Caiyun111111@gmail.com.
^$ 表示空字符,即可理解为空行
[root@vm1 test]# grep -n "^$" text.txt 3: 7:
. 表示匹配任意单个字符
[root@vm1 test]# grep -n "b." text.txt 2:I like badminton, snooker, running 4:Maybe I'm not a smart person, but I'm working hard. 5:My blog is http://www.cnblogs.com/Caiyundo/ 6:Welcome to my blog! CAIYUN
\ 表示转义符
[root@vm1 test]# grep -n "\.$" text.txt 1:My name is Caiyun. 4:Maybe I'm not a smart person, but I'm working hard. 9:My mail is Caiyun111111@gmail.com.
* 表示重复前面0个或1个以上字符
[root@vm1 test]# grep -n "bl*" text.txt 2:I like badminton, snooker, running 4:Maybe I'm not a smart person, but I'm working hard. 5:My blog is http://www.cnblogs.com/Caiyundo/ 6:Welcome to my blog! CAIYUN
.* 表示匹配所有
[root@vm1 test]# grep -n ".*" text.txt 1:My name is Caiyun. 2:I like badminton, snooker, running 3: 4:Maybe I'm not a smart person, but I'm working hard. 5:My blog is http://www.cnblogs.com/Caiyundo/ 6:Welcome to my blog! CAIYUN 7: 8:My qq is 791111890 9:My mail is Caiyun111111@gmail.com.
[] 表示匹配"[]"里面任意单个字符
[root@vm1 test]# grep -n "[791]" text.txt 8:My qq is 791111890 9:My mail is Caiyun111111@gmail.com.
[^] 表示取反"[^]"里面的任意单个字符
[root@vm1 test]# echo Caiyun >> test2.txt [root@vm1 test]# echo 791111890 >> test2.txt [root@vm1 test]# grep -n "[^0-9]" test2.txt 1:Caiyun
[-] 表示匹配"[-]"里一段字符的任意单个字符,如[0-9]即0到9
[root@vm1 test]# grep -n "[0-9]" text.txt 8:My qq is 791111890 9:My mail is Caiyun111111@gmail.com.
1\{4\} 表示匹配字符 "1" 重复4次
[root@vm1 test]# grep -n "1\{4\}" text.txt
8:My qq is 791111890
9:My mail is Caiyun111111@gmail.com.
1\{5,\} 表示匹配字符 "1" 重复5次或5次以上
[root@vm1 test]# grep -n "1\{5,\}" text.txt
9:My mail is Caiyun111111@gmail.com.
1\{,6\} 表示匹配字符 "1" 重复6次和6次以内
[root@vm1 test]# grep -n "1\{,6\}" text.txt
1:My name is Caiyun.
2:I like badminton, snooker, running
3:
4:Maybe I'm not a smart person, but I'm working hard.
5:My blog is http://www.cnblogs.com/Caiyundo/
6:Welcome to my blog! CAIYUN
7:
8:My qq is 791111890
9:My mail is Caiyun111111@gmail.com.
1\{3,5\} 表示匹配字符 "1" 重复3-5次
[root@vm1 test]# grep -n "1\{3,5\}" text.txt
8:My qq is 791111890
9:My mail is Caiyun111111@gmail.com.
二、扩展正则表达式
+ 表示重复 "一个或一个以上" 前面的所有字符("*"是0个)
[root@vm1 test]# grep -n "11111*" text.txt 8:My qq is 791111890 9:My mail is Caiyun111111@gmail.com. [root@vm1 test]# grep -n "11111\+" text.txt 9:My mail is Caiyun111111@gmail.com.
? 表示重复 "0个或一个" 前面的字符("."是有且只有1个)
[root@vm1 test]# grep -n "11111." text.txt 9:My mail is Caiyun111111@gmail.com. [root@vm1 test]# grep -n "11111\?" text.txt 8:My qq is 791111890 9:My mail is Caiyun111111@gmail.com.
| 表示过滤多个字符串
[root@vm1 test]# grep -nE "CAIYUN|mail" text.txt 6:Welcome to my blog! CAIYUN 9:My mail is Caiyun111111@gmail.com. [root@vm1 test]# grep -n "CAIYUN\|mai" text.txt 6:Welcome to my blog! CAIYUN 9:My mail is Caiyun111111@gmail.com.
一般情况下,当我们需要用到扩展正则表达式匹配符时,使用grep要加参数 ”-E” 或用 “\” 转译符转义匹配符
三、元字符
\b 边界字符,单词边界
[root@vm1 test]# grep 'Caiyun' text.txt My name is Caiyun. My blog is http://www.cnblogs.com/Caiyundo/ My mail is Caiyun111111@gmail.com. [root@vm1 test]# grep 'Caiyun\b' text.txt My name is Caiyun.
grep的用法还有很多,只要符合规则、逻辑,还可以和很多其他命令配合使用。
PS:要活学活用,多用多练。
Linux三剑客之老三grep的更多相关文章
- 第十二章 Linux三剑客之老三—grep
一.Linux grep 命令用于查找文件里符合条件的字符串. Linux系统中的grep命令是一种功能强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来.grep全称是Global ...
- 性能工具之linux三剑客awk、grep、sed详解
前言 linux 有很多工具可以做文本处理,例如:sort, cut, split, join, paste, comm, uniq, column, rev, tac, tr, nl, pr, he ...
- Linux 三剑客 -- awk sed grep
本文由本人收集整理自互联网供自己与网友参考,参考文章均已列出,如有侵权,请告知! 顶配awk,中配sed,标配grep awk 参考 sed 参考 grep 参考 在线查看linux命令速记表 app ...
- Linux三剑客及使用介绍
Linux 三剑客是(grep,sed,awk)三者的简称,熟练使用这三个工具可以提升运维效率.Linux 三剑客以正则表达式作为基础,而在Linux系统中,支持两种正则表达式,分别为"标准 ...
- Linux三剑客老三---grep
1.Linux三剑客老三 过滤需要的内容,例子:grep -v oldboy hello.txt grep一般常用参数: -a:在二进制文件中,以文本文件的方式搜索数据. -c:计算找到"搜 ...
- (转)不看绝对后悔的Linux三剑客之grep实战精讲
不看绝对后悔的Linux三剑客之grep实战精讲 原文:http://blog.51cto.com/hujiangtao/1923675 https://www.cnblogs.com/peida/a ...
- Linux三剑客之grep常用参数详细总结
三剑客grep总结 grep : Linux三剑客老三 过滤需要的内容 参数: grep一般常用参数: -a :在二进制文件中,以文本文件的方式搜索数据 -c :计算找到 ’ 搜索字符串 ...
- Linux三剑客grep、awk、sed
何为Linux三剑客? 第一个剑客是 grep,grep 会根据正则表达式查找相关内容并打印对应的数据. 第二个剑客是 awk,awk 的名字来源于三个作者的名字简称,它可以根据定位到的数据行处理其中 ...
- Linux三剑客grep、awk和sed
grep,sed 和 awk是Linux/Unix 系统中常用的三个文本处理的命令行工具,称为文本处理三剑客.本文将简要介绍这三个命令并给出基本用法. 管道 在介绍这两个命令之前,有必要介绍一下Uni ...
随机推荐
- ip_local_port_range 和 ip_local_reserved_ports
问题:启动应用程序时,发现网络端口被占用,原因是什么?如何避免? 原因:Linux 系统设置了随机使用的端口范围 echo "40000 60000" > /proc/. ...
- 【做题记录】[NOI2008] 假面舞会—有向图上的环与最长链
luogu 1477 [NOI2008] 假面舞会 容易发现: 如果图中没有环,那么面具种数一定是所有联通块内最长链之和,最少为 \(3\) . 如果有环,则面具种数一定是所有环的大小的最大公约数. ...
- Envoy实现.NET架构的网关(二)基于控制平面的动态配置
什么是控制平面 上一篇我们讲了文件系统的动态配置,这次我们来看看通过Control Panel来配置Envoy.控制平面就是一个提供Envoy配置信息的单独服务,我们可以通过这个服务来修改Envoy的 ...
- 网关服务spring cloud zuul
Zuul例子配置文件 spring.application.name=switch-gateway server.port=5555 请求路由 传统路由方式 zuul.routes.api-a-url ...
- kubernetes常见日志采集问题和解决方案分析
传统日志与kubernetes日志对比 传统服务 目录固定 重启不会丢失 不用关注标准与错误日志输出 容器服务 节点不固定 重启服务会漂移 需要关注标准与错误日志输出 日志文件重启会丢失 日志目录不固 ...
- SpringBoot 整合thymeleaf
1.Thymeleaf介绍(官网推荐:https://www.thymeleaf.org/doc/articles/thymeleaf3migration.html) Thymeleaf是跟Veloc ...
- 一文带你理解TDengine中的缓存技术
作者 | 王明明,涛思数据软件工程师 小 T 导读:在计算机系统中,缓存是一种常用的技术,既有硬件缓存,比如我们经常听到的 CPU L2 高速缓存,也有软件缓存,比如很多系统里把 Redis 当做数据 ...
- CobaltStrike上线Linux
为获得最佳的阅读体验,请访问我的个人主页: https://xzajyjs.cn/ 在红蓝对抗中,我们常需要对目标进行长时间的控制,cobaltstrike原生对于上线windows比较轻松友好,但如 ...
- Linux usb 3. Host 详解
文章目录 1. 简介 2. Usb Core 驱动设备模型 2.1 Usb Device Layer 2.1.1 device (struct usb_device) 2.1.2 driver (st ...
- SpringCloud config native 配置
1.概述 最近项目使用springCloud 框架,使用config搭建git作为配置中心. 在私有化部署中,出现很多比较麻烦的和鸡肋的设计. 每次部署都需要安装gitlab 有些环境安装完gitla ...