首页 > 系统相关 >软件测试/测试开发|一文详解Linux grep命令

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

时间:2023-12-26 18:24:37浏览次数:45  
标签:grep like mia am Linux 匹配 txt 软件测试

简介

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 -n
1:I am a coach
2:I am a player
3:I like Linux
4:I like python
16:i believe i can fly

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

  1. 输出以.结尾的行
 grep "\.$" test.txt -n
10: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 -n
6:
12:
15:
  1. 查找有内容的行

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

$ grep "." test.txt -n
1:I am a coach
2:I am a player
3:I like Linux
4:I like python
5:hello world
7:mia san mia
8:12312341
9:321789
10:abcdrstxyz.
11:efglmnuvw.
13:#tigaffpubg
14:#theshyrookie
16:i believe i can fly
  1. "*"符号

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

$ grep "i*" test.txt -n
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. .*组合符

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

$ grep ".*" test.txt -n
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. []中括号

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

  • [a-z]匹配所有小写单个字母[A-Z]匹配所有单个大写字母
  • [a-zA-Z]匹配所有的单个大小写字母
  • [0-9]匹配所有单个数字
  • [a-zA-ZO-9]匹配所有数字和字母

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

$ grep "[abc]" test.txt -n
1:I am a coach
2:I am a player
7:mia san mia
10:abcdrstxyz.
13:#tigaffpubg
16:i believe i can fly

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

  1. -o参数

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

 grep "[abc]" test.txt -n -o
1:a
1:a
1:c
1:a
1:c
2:a
2:a
2:a
7:a
7:a
7:a
10:a
10:b
10:c
13:a
13:b
16:b
16:c
16:a

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

$ grep "[abc]" test.txt -c
6

扩展正则表达式grep

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

  1. +

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

$ grep -E "i+" test.txt -n
3:I like Linux
4:I like python
7:mia san mia
13:#tigaffpubg
14:#theshyrookie
16:i believe i can fly
  1. ?

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

$ grep -E "li?e" test.txt  -n
16: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 coach
I am a player
mia san mia
abcdrstxyz.
#tigaffpubg
i believe i can fly

总结

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

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

标签:grep,like,mia,am,Linux,匹配,txt,软件测试
From: https://www.cnblogs.com/hogwarts/p/17929001.html

相关文章

  • 软件测试/测试开发|测试用例设计方法——边界值
    前言我们之前介绍了等价类测试用例设计方法,但是等价类测试用例设计方法容易存在问题,即我们取的值不一定在我们程序设计的边界附近,但是在我们的测试实践中,问题往往都是出在输入定义域或输出值域的边界上,而不是在其内部。因此,针对各种边界情况设计测试用例,通常可能会发现更多的bug......
  • 软件测试/测试开发|测试用例设计方法——等价类划分
    前言在软件测试领域,测试用例设计是确保软件系统质量的关键环节之一。等价类划分法(EquivalencePartitioning)是一种被广泛采用的测试用例设计技术,它通过将输入数据划分为相互等价的类别,以确保在每个等价类中选择适当的测试用例,从而提高测试的全面性和效率。1.了解等价类划分法......
  • 软件测试/测试开发|软件测试基础概念
    前言在我们使用各种App访问各个网站时,偶尔会出现软件崩溃,加载缓慢,或者出现报错的情况,而这两年,我们也见过了很多大厂的App出现问题,比如美团外卖,比如阿里云和微信都出现过问题,而要避免出现上述这些大的问题,就需要我们在软件上线之前尽可能的发现软件的问题,这就是我们所说的测试,即对软......
  • 软件测试/测试开发|一文告诉你什么是测试用例
    前言对于一个测试工程师来说,测试用例的编写是一项必须掌握的能力,但有效的设计和熟练的编写确实一项十分复杂的技术。不仅需要掌握软件测试技术和流程,而且还要对整个软件不管从业务,还是对软件的设计,程序模块的结构,功能规格等说明都要有透彻的理解。测试的设计方法不是单独存在的,具体......
  • 软件测试/测试开发|测试用例设计和评审应该怎么做,一篇文章告诉你?
    测试用例简介测试用例(TestCase)是为项目需求而编制的一组测试输入、执行条件以及预期结果,以便测试某个程序是否满足客户需求,可以总结为:每一个测试点的数据设计和步骤设计对需求分析找出来的每一个功能点,进行数据的设计、步骤的设计、预期的结果。测试用例的目的(为什么使用测试用例?)1......
  • 软件测试面试——项目相关的几个问题
    ......
  • Linux相关扫盲1
    1、Linux操作系统发行版有哪些?Ubuntu: 一个以桌面应用为重点的发行版,也有服务器版本。Fedora: 由全球志愿者社区支持的发行版,注重在新技术的采用上。Debian: 以稳定性和开放性著称,是许多其他发行版的基础。CentOS: 以稳定性和长期支持为目标,被广泛用于服务器环境。ArchLinux......
  • Linux进阶(二)
    一、常用的一些基本命令1、管理文件和目录的命令命令功能命令功能pwd显示当前目录ls查看目录下的内容cd改变所在目录cat显示文件的内容grep在文件中查找某字符cp复制文件touch创建文件mv移动文件rm删除文件rmdir删除目录2、在文件系统中查找文件和目录find/home/soft-name"file_......
  • Linux驱动开发之杂项设备注册和Linux2.6设备注册
    Linux设备驱动开发中,需要向内核正确注册设备,才能创建设备节点,以供应用层访问。本文将详细介绍Linux下的两种设备注册方法:杂项设备注册和Linux2.6新方法注册。一、杂项设备注册杂项设备注册简介杂项设备注册是Linux驱动开发中的一种设备注册方式。在Linux系统中,杂项设备是一类......
  • grep -Ev '#|^$' zabbix_server.conf 显示配置文件 命令
    grep-Ev'#|^$'zabbix_server.confroot@k8s-node01:/etc/zabbix#grep-Ev'#|^$'zabbix_server.confLogFile=/var/log/zabbix/zabbix_server.logLogFileSize=0PidFile=/run/zabbix/zabbix_server.pidSocketDir=/run/zabbixDBName=zabbixDBUser=......