说明:

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的更多相关文章

  1. 第十二章 Linux三剑客之老三—grep

    一.Linux grep 命令用于查找文件里符合条件的字符串. Linux系统中的grep命令是一种功能强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来.grep全称是Global ...

  2. 性能工具之linux三剑客awk、grep、sed详解

    前言 linux 有很多工具可以做文本处理,例如:sort, cut, split, join, paste, comm, uniq, column, rev, tac, tr, nl, pr, he ...

  3. Linux 三剑客 -- awk sed grep

    本文由本人收集整理自互联网供自己与网友参考,参考文章均已列出,如有侵权,请告知! 顶配awk,中配sed,标配grep awk 参考 sed 参考 grep 参考 在线查看linux命令速记表 app ...

  4. Linux三剑客及使用介绍

    Linux 三剑客是(grep,sed,awk)三者的简称,熟练使用这三个工具可以提升运维效率.Linux 三剑客以正则表达式作为基础,而在Linux系统中,支持两种正则表达式,分别为"标准 ...

  5. Linux三剑客老三---grep

    1.Linux三剑客老三 过滤需要的内容,例子:grep -v oldboy hello.txt grep一般常用参数: -a:在二进制文件中,以文本文件的方式搜索数据. -c:计算找到"搜 ...

  6. (转)不看绝对后悔的Linux三剑客之grep实战精讲

    不看绝对后悔的Linux三剑客之grep实战精讲 原文:http://blog.51cto.com/hujiangtao/1923675 https://www.cnblogs.com/peida/a ...

  7. Linux三剑客之grep常用参数详细总结

    三剑客grep总结 grep  : Linux三剑客老三      过滤需要的内容 参数: grep一般常用参数: -a :在二进制文件中,以文本文件的方式搜索数据 -c :计算找到 ’ 搜索字符串 ...

  8. Linux三剑客grep、awk、sed

    何为Linux三剑客? 第一个剑客是 grep,grep 会根据正则表达式查找相关内容并打印对应的数据. 第二个剑客是 awk,awk 的名字来源于三个作者的名字简称,它可以根据定位到的数据行处理其中 ...

  9. Linux三剑客grep、awk和sed

    grep,sed 和 awk是Linux/Unix 系统中常用的三个文本处理的命令行工具,称为文本处理三剑客.本文将简要介绍这三个命令并给出基本用法. 管道 在介绍这两个命令之前,有必要介绍一下Uni ...

随机推荐

  1. greenplum分布键的hash值计算分析

    greenplum 数据分布策略 greenplum 是一个 MPP 架构的数据库,由一个 master 和多个 segment 组成(还可选配置一个 standby master),其数据会根据设置 ...

  2. wpa_supplicant启动出错rfkill: Cannot open RFKILL control device

    在板子是调试网络,千辛万苦把wpa_supplicant及其依赖都移植编译进来了,在板子上调试启动的时候启动报错了 D/wpa_supplicant( 1152): wpa_supplicant v2 ...

  3. Beam Search快速理解及代码解析

    目录 Beam Search快速理解及代码解析(上) Beam Search 贪心搜索 Beam Search Beam Search代码解析 准备初始输入 序列扩展 准备输出 总结 Beam Sea ...

  4. Jmeter 运行结果的csv文件生成报告

    把运行结果保存到本地,下次可以直接用结果生成测试报告. 一.首先保证脚本能正常运行 二.本地创建csv文件,用来保存运行结果 三.察看结果树,选择本地文件(上一步创建好的csv文件),保存运行结果,如 ...

  5. 怎么将本地已有的一个项目上传到新建的git仓库的方法

    将本地已有的一个非git项目上传到新建的git仓库的方法一共有两种. 一. 克隆+拷贝 第一种方法比较简单,直接用把远程仓库拉到本地,然后再把自己本地的项目拷贝到仓库中去.然后push到远程仓库上去即 ...

  6. 六问六答理解ForkJoin原理

    摘要:ForkJoin线程池是将任务分割为子任务,有可能子任务还是很大,还需要进一步拆解,最终得到足够小的任务. 本文分享自华为云社区<ForkJoin线程池的学习和思考>,作者:brea ...

  7. SSH服务器拒绝了密码。请再试一次。怎么改都不行

    使用Xshell连接服务器,之前还好好的,突然之间就报"SSH服务器拒绝了密码.请再试一次"的错误. 1.检查 检查了IP.连接端口.用户.密码.网络是否正确? 本机情况:能够pi ...

  8. zookeeper问题在公司可以 回到家用家里网不行 目前还没有解决

    Opening socket connection to server 192.168.1.193/192.168.1.193:2181. Will not attempt to authentica ...

  9. 详解电子表格中的json数据:序列化与反序列化

    从XML到JSON 当下应用开发常见的B/S架构之下,我们会遇到很多需要进行前后端数据传输的场景.而在这个传输的过程中,数据通过何种格式传输.方式是否迅速便捷.书写方式是否简单易学,都成为了程序员在开 ...

  10. C#窗体学习

    //进度条控件 private void button1_Click(object sender, EventArgs e)        {            int i;            ...