grep 的全称是 Globally search a Regular Expression and Print,是一种强大的文本搜索工具,它能使用特定模式匹配(包括正则表达式)搜索文本,并默认输出匹配行

我们程序员最常用的是查找指定的线程:

去查找指定的进程:ps -ef | grep ***

grep提供两种方式:

grep [option] [pattern] testfile
stdout | grep [option] [pattern]
语法格式 解释
option 参数选项
pattern 为查找的字符串或者正则表达式

第一种是从文本中直接使用pattern匹配搜索

第二种是从标准输出中处理 grep所提供的option(参数选项)

参数选项 含义
-i 搜索时略大小写
-n 显示行号
-o 只显示被匹配的关键字,不会打印匹配的整行内容
-r 递归搜索
-v 不显示匹配行信息
-q 静默模式,不输出任何信息,在 shel 脚本中,可以通过 echo$?查看是否匹配到,0 表示匹配到,1 表示没有匹配到
-E 使用扩展正则表达式

接下来测试一下:

# 创建一个文件,内容如下:
[root@master tmp_test]# cat test.txt
test
math test
sunday
sunny
java
python
shell
ruby Test # 查找 test
[root@master tmp_test]# grep "test" test.txt
test
math test
发现 grep 区分大小写,Test 就没有查出来。 # 不区分大小写
[root@master tmp_test]# grep -i "test" test.txt
test
math test
ruby Test # 把行号打印出来
[root@master tmp_test]# grep -i -n "test" test.txt
1:test
2:math test
8:ruby Test # 只想查看关键字,行内其他内容忽略
[root@master tmp_test]# grep -i -n -o "test" test.txt
1:test
2:test
8:Test # 查看当前文件夹下多个文件里面字符匹配
# 拷贝一份并充命名
[root@master tmp_test]# cp test.txt test1.txt
# 退回到上一级目录
[root@master tmp_test]# cd ..
# 搜索当前文件夹内的文字匹配
[root@master home]# grep -r -i -n "test" tmp_test/
tmp_test/test1.txt:1:test
tmp_test/test1.txt:2:math test
tmp_test/test1.txt:8:ruby Test
tmp_test/test.txt:1:test
tmp_test/test.txt:2:math test
tmp_test/test.txt:8:ruby Test # -q 表是静默静默模式,在此模式下grep命令不会有任何的打印结果,无论是否有匹配到。 #通过我们会把结果输出到一个文件中
[root@master home]# grep -r -i -n "test" tmp_test/ >> tmp_test/result # 实际编写脚本时,需要判断是否有输出数据,用 $? 来判断
[root@master tmp_test]# grep -i -n -q "test" test.txt
[root@master tmp_test]# echo $?
0
[root@master tmp_test]# grep -i -n -q "teeeest" test.txt
[root@master tmp_test]# echo $?
1 0 表是有输出数据,1表示没有输出数据。

grep 结合正则表达式:

上面说了,grep 的全称是 Globally search a Regular Expression and Print。

grep 之所以强大,就是因为可是使用正则。

基本正则表达式

语法 含义
. 单个字符
* 表示前面的字符连续出现任意次,包括0次
^ 表示锚定行首
$ 表示锚定行尾
[a-z] [0-9] 区间范围

扩展正则,匹配是需要加 -E

语法 含义
表示匹配其前面的字符0或1次
+ 表示匹配其前面的字符至少1次,或者连续多次,连续次数上不封顶。
() 分组
{} 连续匹配
| 匹配多个表达式的任何一个
#查询 以“test”开头的
[root@master tmp_test]# grep "^test" test.txt
test #查询 以“test”结尾的
[root@master tmp_test]# grep "test$" test.txt
test
math test # 查询含有两个连续n,并且以y结尾的
[root@master tmp_test]# grep -E "*n{2}y$" test.txt
sunny

grep 配合正则还可以做很多事情,有实际需要时记得及时查资料。

shell 三剑客之 grep的更多相关文章

  1. shell三剑客之grep

    背景 对于很多的测试人员来说,grep命令都很熟悉,用的最多的比如去查找指定的进程:ps -ef | grep *** ,其中***为进程名或进程号,这里我们只用到的grep的最基础功能-从标准输出中 ...

  2. Linux进阶之正则,shell三剑客(grep,awk,sed),cut,sort,uniq

    一.正则表达式:Regular Expression 正则表达式:正则表达式使用单个字符串来描述.匹配一系列符合某个句法规则的字符串.在很多文本编辑器里,正则表达式通常被用来检索.替换那些符合某个模式 ...

  3. Shell—三剑客(grep、sed、awk)

    grep命令详解 文本搜索工具,根据用户指定的“模式(pattern)”对目标文本进行过滤,显示被模式匹配到的行. 命令格式:grep  [options]  pattern  filename.gr ...

  4. shell 文本处理三剑客之 grep 和 egrep

    shell 三剑客之 grep 命令语法格式 grep 参数 案例 显示file中有python的行 grep python file 显示没有python的行,不忽略大小写 grep -v pyth ...

  5. shell脚本三剑客:grep、sed、awk

    shell脚本三剑客:grep  sed  awk grep语法: grep [OPTIONS] PATTERN [FILE] 常用选项 -c                       统计匹配到的 ...

  6. linux三剑客之grep

    linux基础三剑客之grep 1.grep命令 基本介绍 grep命令是文本本过滤工具,是基于一个模式匹配文件的每一行,grep分类:egrep个fgrep. grep英文名:Global  sea ...

  7. Linux文本处理三剑客之grep及正则表达式详解

    Linux文本处理三剑客之grep及正则表达式详解 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.Linux文本处理三剑客概述 grep: 全称:"Global se ...

  8. Linux文本处理三剑客之——grep

    一Linux文本处理三剑客之——grep Linux文本处理三剑客都支持正则表达式 grep :文本过滤( 模式:pattern) 工具,包括grep, egrep, fgrep (不支持正则表达式) ...

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

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

随机推荐

  1. MAVEN无法下载com.oracle:jdbc14:jar解决办法

    原文链接:https://www.cnblogs.com/gqzdev/p/11742999.html 第一步,下载ojdbc14jar包: 链接:ojdbc14jar 提取码: 2m59 第二步,下 ...

  2. 爬虫管理平台以及wordpress本地搭建

    爬虫管理平台以及wordpress本地搭建 学习目标: 各爬虫管理平台了解 scrapydweb gerapy crawlab 各爬虫管理平台的本地搭建 Windows下的wordpress搭建 爬虫 ...

  3. PHP juliantojd() 函数

    ------------恢复内容开始------------ 实例 把儒略历法的日期转换为儒略日计数,然后再转换回儒略历法的日期: <?php$jd=juliantojd(6,20,2007); ...

  4. PHP is_writable() 函数

    定义和用法 is_writable() 函数检查指定的文件是否可写. 如果文件可写,该函数返回 TRUE. 语法 is_writable(file) 参数 描述 file 必需.规定要检查的文件. 提 ...

  5. PHP xml_get_current_byte_index() 函数

    定义和用法 xml_get_current_byte_index() 函数获取 XML 解析器的当前字节索引.高佣联盟 www.cgewang.com 如果成功,该函数则返回当前字节索引.如果失败,则 ...

  6. bzoj 4305 数列的GCD

    LINK:数列的GCD 题意: 给出一个长度为N的数列{a[n]},1<=a[i]<=M(1<=i<=N). 现在问题是,对于1到M的每个整数d,有多少个不同的数列b[1], ...

  7. “随手记”开发记录day07

    今天完成了关于我们页面中的相关信息,由于之前没有做过这个东西,只想着用一个view解决 可是发现我们整的太简单了,还是太年轻,最后想出来要跟java代码一起解决这个问题, 效果

  8. VSFTP问题解决

    支持 root 登录 在 /etc/vsftpd/{ftpusers,user_list} 中注释掉 root 添加 allow_writeable_chroot=YES, 允许在只读文件登录, 否则 ...

  9. 使用cors完成跨域请求处理

    跨域的含义 同源策略以及其限制内容 同源策略是一种约定,它是浏览器最核心也最基本的安全功能,如果缺少了同源策略,浏览器很容易受到XSS.CSFR等攻击.所谓同源是指"协议+域名+端口&quo ...

  10. Apache Hudi表自动同步至阿里云数据湖分析DLA

    1. 引入 Hudi 0.6.0版本之前只支持将Hudi表同步到Hive或者兼容Hive的MetaStore中,对于云上其他使用与Hive不同SQL语法MetaStore则无法支持,为解决这个问题,近 ...