写点什么

软件测试 / 测试开发|一文详解 Linux grep 命令

  • 2023-12-21
    北京
  • 本文字数:2064 字

    阅读完需:约 7 分钟

简介

grep命令是最常用的 Linux 命令之一,用于对文件和文本执行重复搜索的工具,功能非常强大,也是我们必须学习掌握的 Linux 三剑客之一,本文就给大家介绍一下grep命令的使用。

grep 的基本语法

grep作为一款文本搜索工具,可以根据用户指定的“模式(过滤条件)”对目标文本逐行进行匹配检查,打印匹配到的行,基本的语法如下:


grep [options] [pattern] file
命令 参数 匹配模式 文件
复制代码


常用的参数如下:


  • -i:忽略模式中的字母大小写。

  • -c:仅列出文件中包含模式的行数。

  • -l:列出带有匹配行的文件名。

  • -v:列出没有匹配模式的行。

  • -w: 把表达式当做一个完整的单字符来搜寻,忽略那些部分匹配的行。

  • -o:只输出匹配的内容。

  • -E:使用egrep命令。

grep 命令使用实践

首先我们来看一下我们需要操作的文件的内容,命令如下:


cat -n test.txt     1  I am a coach     2  I am a player     3  I like Linux     4  I like python     5  hello world     6       7  mia san mia     8  12312341     9  321789    10  abcdrstxyz.    11  efglmnuvw.    12      13  #tigaffpubg    14  #theshyrookie    15      16  i believe i can fly
复制代码


  1. 输出以I 开头的行(不区分大小写)


 grep "^i" test.txt -i -n1:I am a coach2:I am a player3:I like Linux4:I like python16:i believe i can fly
复制代码


注: 这里的-i参数代表不区分大小写, -n参数代表显示匹配行和行号


  1. 输出以.结尾的行


 grep "\.$" test.txt -n10:abcdrstxyz.11:efglmnuvw.
复制代码


注: 因为.在这里有着特殊含义, 所以要用\转义一下, 如果不加转义字符的话, grep 就会把它当做正则表达式来处理(.代表的含义是匹配任意一个字符)


  1. $符号


在 Linux 平台下, 所有文件每行结尾都有一个$符,我们可以使用cat命令进行查看,如下:


$ cat -A test.txt I am a coach$I am a player$I like Linux$I like python$hello world$$mia san mia$12312341$321789$abcdrstxyz.$efglmnuvw.$$#tigaffpubg$#theshyrookie$$i believe i can fly$
复制代码


  1. 查找空行


^$即表示空行,找出空行的命令如下:


$ grep "^$" test.txt -n6:12:15:
复制代码


  1. 查找有内容的行


.点表示任意一个字符, 有且只有一个, 不包含空行,所以输出有内容的行命令如下:


$ grep "." test.txt -n1:I am a coach2:I am a player3:I like Linux4:I like python5:hello world7:mia san mia8:123123419:32178910:abcdrstxyz.11:efglmnuvw.13:#tigaffpubg14:#theshyrookie16:i believe i can fly
复制代码


  1. "*"符号


*表示找出前一个字符 0 次或一次以上,命令如下:


$ grep "i*" test.txt -n1:I am a coach2:I am a player3:I like Linux4:I like python5:hello world6:7:mia san mia8:123123419:32178910:abcdrstxyz.11:efglmnuvw.12:13:#tigaffpubg14:#theshyrookie15:16:i believe i can fly
复制代码


  1. .*组合符


.*表示所有内容, 包括空行,示例代码如下:


$ grep ".*" test.txt -n1:I am a coach2:I am a player3:I like Linux4:I like python5:hello world6:7:mia san mia8:123123419:32178910:abcdrstxyz.11:efglmnuvw.12:13:#tigaffpubg14:#theshyrookie15:16:i believe i can fly
复制代码


  1. []中括号


中括号表达式,[abc]表示匹配中括号中任意一个字符, abc,常见的形式如下,


  • [a-z]匹配所有小写单个字母[A-Z]匹配所有单个大写字母

  • [a-zA-Z]匹配所有的单个大小写字母

  • [0-9]匹配所有单个数字

  • [a-zA-ZO-9]匹配所有数字和字母


匹配abc字符中的任意一个,得到它的行数和行号


$ grep "[abc]" test.txt -n1:I am a coach2:I am a player7:mia san mia10:abcdrstxyz.13:#tigaffpubg16:i believe i can fly
复制代码


注:如果我们想查看不包含abc字符的行,则可以写成[^abc]


  1. -o参数


使用-o参数, 可以值显示被匹配到的关键字, 而不是将整行的内容都输出。命令如下:


 grep "[abc]" test.txt -n -o1:a1:a1:c1:a1:c2:a2:a2:a7:a7:a7:a10:a10:b10:c13:a13:b16:b16:c16:a
复制代码


查看一共有多少行,我们可以改用-c参数,命令如下:


$ grep "[abc]" test.txt -c6
复制代码

扩展正则表达式 grep

grep命令结合正则之后,功能将更为强大,我们这里使用-E进行正则扩展。


  1. +


+号表示匹配前一个字符 1 一次或多次,必须使用grep -E扩展正则,命令如下:


$ grep -E "i+" test.txt -n3:I like Linux4:I like python7:mia san mia13:#tigaffpubg14:#theshyrookie16:i believe i can fly
复制代码


  1. ?


匹配前一个字符 0 次或 1 次,命令使用如下:


$ grep -E "li?e" test.txt  -n16:i believe i can fly
复制代码


  1. {n,m}匹配次数


  • {n,m}:匹配前一个字符至少 n 次, 最多 m 次

  • {n,}: 匹配前一个字符至少 n 次, 没有上限

  • {,m}: 匹配前一个字符最多 m 次,可以没有


示例命令如下:


$ grep -E "a{1,3}" test.txt I am a coachI am a playermia san miaabcdrstxyz.#tigaffpubgi believe i can fly
复制代码

总结

本文主要介绍了 Linux 三剑客中的grep命令的使用,这是一个功能非常强大的文本内容搜索工具,熟练的使用grep命令,对于我们学好软件测试开发的课程有很大的帮助,希望本文能够帮到大家!


获取更多技术资料,请点击!



用户头像

社区:ceshiren.com 微信:ceshiren2021 2019-10-23 加入

微信公众号:霍格沃兹测试开发 提供性能测试、自动化测试、测试开发等资料,实时更新一线互联网大厂测试岗位内推需求,共享测试行业动态及资讯,更可零距离接触众多业内大佬。

评论

发布
暂无评论
软件测试/测试开发|一文详解Linux grep命令_霍格沃兹测试开发学社_InfoQ写作社区