一、背景
对于很多的测试人员来说,grep命令都很熟悉,用的最多的比如去查找指定的进程:ps -ef | grep ***
其中***为进程名或进程号,这里我们只用到的grep的最基础功能-从标准输出中过滤指定的字符串,实际上grep的功能远不止如此。
这篇文章给大家来介绍下grep的进阶及高阶用法,来帮助我们在测试工作中提升效率。
grep的全称:Global search Regular Expression and Print out the line。
是一种强大的文本搜索工具,它能使用特定模式匹配(包括正则表达式)搜索文本,并默认输出匹配行。
grep和sed、awk一起成为linux中的三剑客。
grep可以不使用正则,但是跟正则一起配合使用时,功能最为强大!
二、命令语法
grep提供两种方式:
◆ grep [option] [pattern] testfile
◆ stdout | grep [option] [pattern]
第一种是从文本中直接使用pattern匹配搜索
第二种是从标准输出中处理 grep所提供的option(参数选项)
我们先从第一个最简单的示例开始:先准备一个测试文件。
内容如下:
从文本文件中搜索test字符串
可以看到包含有"test"的行被打印出来,默认grep是区分大小写的。
所以"Test","TEST"没有被匹配出来。
如果想要不区分大小写,我们可以加"-i"的参数。
如下:
当前我们的测试文本内容比较少,我们肉眼可以见到是在第几行。
如果文本行数较多的情况下那就不太方便了,这里就可以用到"-n"的参数
包含有"test"的并且不区分大小写的行在开头会显示行号,现在的结果中匹配的关键字所在行全部内容都会输出。
如果只想要看到匹配的关键字,怎么办?
使用"-o"参数即可
有时候我们需要对整个目录去搜索关键字,如果直接使用grep "test" 目录名,会报错。
加参数'-r'就可以避免这个问题
可以看到shellTest目录下的两支文件test1.txt以及testfile都包含test被打印出来了
“-q”选项表示使用静默模式,在此模式下grep命令不会有任何的打印结果,无论是否有匹配到。
一般来说我们可以根据echo $?
来查看上一条指令(grep)的执行结果,如果返回结果为0,表示grep有匹配到了,如果返回结果为1,表示grep没有匹配到。
一般我们可以shell脚本中去用if条件分支进行判断,如果echo%20$?结果为0,就去执行相应的操作
三、grep结合pattern正则
前面我们介绍了参数的基本用法,grep的强大之处其实是和正则表达式一起才有作用。
注:本篇文章不会具体介绍正则表达式的使用,如果不了解正则表达式的同学推荐去看下之前相关的文章
我们知道在正则表达式中分为了两类:
01%20基本正则表达式
◆%20.%20单个字符
◆%20*%20表示前面的字符连续出现任意次,包括0次
◆%20^%20表示锚定行首
◆%20$%20表示锚定行尾
◆%20[a-z]%20[0-9]%20区间范围
......
02%20扩展正则表达式
◆%20?表示匹配其前面的字符0或1次
◆%20+%20表示匹配其前面的字符至少1次,或者连续多次,连续次数上不封顶。
◆%20()%20分组
◆%20{}%20连续匹配
◆%20|%20匹配多个表达式的任何一个
......
如查询以"lemon"单词开头
查找文件中空白行的数量
正则“^$”表示空白行,参数“-c”表达计算行数
连续字数的正则匹配,如:查找“Appium”,p是连续的
“{2}”表示p连续出现了两次,可以发现结果是匹配不到的。
因为{}是扩展正则表达式,grep默认是基本正则表达式,如果需要支持扩展正则表达式,我们需要加"-E"选项:
本文由柠檬班歪歪原创,转载需注明出处!