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

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

image.png

简介

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命令,对于我们学好软件测试开发的课程有很大的帮助,希望本文能够帮到大家!

相关文章
|
6天前
|
Linux
在 Linux 系统中,“cd”命令用于切换当前工作目录
在 Linux 系统中,“cd”命令用于切换当前工作目录。本文详细介绍了“cd”命令的基本用法和常见技巧,包括使用“.”、“..”、“~”、绝对路径和相对路径,以及快速切换到上一次工作目录等。此外,还探讨了高级技巧,如使用通配符、结合其他命令、在脚本中使用,以及实际应用案例,帮助读者提高工作效率。
24 3
|
6天前
|
监控 安全 Linux
在 Linux 系统中,网络管理是重要任务。本文介绍了常用的网络命令及其适用场景
在 Linux 系统中,网络管理是重要任务。本文介绍了常用的网络命令及其适用场景,包括 ping(测试连通性)、traceroute(跟踪路由路径)、netstat(显示网络连接信息)、nmap(网络扫描)、ifconfig 和 ip(网络接口配置)。掌握这些命令有助于高效诊断和解决网络问题,保障网络稳定运行。
18 2
|
11天前
|
机器学习/深度学习 前端开发 测试技术
探索软件测试中的自动化测试框架选择与优化策略####
本文深入探讨了在当前软件开发生命周期中,自动化测试框架的选择对于提升测试效率、保障产品质量的重要性。通过分析市场上主流的自动化测试工具,如Selenium、Appium、Jest等,结合具体项目需求,提出了一套系统化的选型与优化策略。文章首先概述了自动化测试的基本原理及其在现代软件开发中的角色变迁,随后详细对比了各主流框架的功能特点、适用场景及优缺点,最后基于实际案例,阐述了如何根据项目特性量身定制自动化测试解决方案,并给出了持续集成/持续部署(CI/CD)环境下的最佳实践建议。 --- ####
|
6天前
|
安全 网络协议 Linux
本文详细介绍了 Linux 系统中 ping 命令的使用方法和技巧,涵盖基本用法、高级用法、实际应用案例及注意事项。
本文详细介绍了 Linux 系统中 ping 命令的使用方法和技巧,涵盖基本用法、高级用法、实际应用案例及注意事项。通过掌握 ping 命令,读者可以轻松测试网络连通性、诊断网络问题并提升网络管理能力。
24 3
|
9天前
|
Linux
在 Linux 系统中,`find` 命令是一个强大的文件查找工具
在 Linux 系统中,`find` 命令是一个强大的文件查找工具。本文详细介绍了 `find` 命令的基本语法、常用选项和具体应用示例,帮助用户快速掌握如何根据文件名、类型、大小、修改时间等条件查找文件,并展示了如何结合逻辑运算符、正则表达式和排除特定目录等高级用法。
35 6
|
10天前
|
监控 Linux 开发者
如何在 Linux 中优雅的使用 head 命令,用来看日志简直溜的不行
`head` 命令是 Linux 系统中一个非常实用的工具,用于快速查看文件的开头部分内容。本文介绍了 `head` 命令的基本用法、高级用法、实际应用案例及注意事项,帮助用户高效处理文件和日志,提升工作效率。
22 7
|
11天前
|
监控 Linux
Linux常用命令-2
本文继续介绍Linux常用命令,涵盖目录操作、文件操作、系统信息和进程管理等类别。具体包括mkdir、rmdir、cp、mv、rm、touch、whereis、whatis、dmesg、free、date、cal、ps、kill、killall和top等命令的使用方法和常用参数。
41 7
|
10天前
|
监控 Linux Perl
Linux 命令小技巧:显示文件指定行的内容
在 Linux 系统中,处理文本文件是一项常见任务。本文介绍了如何使用 head、tail、sed 和 awk 等命令快速显示文件中的指定行内容,帮助你高效处理文本文件。通过实际应用场景和案例分析,展示了这些命令在代码审查、日志分析和文本处理中的具体用途。同时,还提供了注意事项和技巧,帮助你更好地掌握这些命令。
24 4
|
9天前
|
缓存 网络协议 Linux
Linux ip命令常用操作
Linux的 `ip`命令是一个强大且灵活的网络管理工具,能够执行从基本的网络接口配置到高级的路由和VLAN管理等多种操作。通过熟练掌握这些常用操作,用户可以更加高效地管理和配置Linux系统的网络环境。无论是在日常管理还是故障排除中,`ip`命令都是必不可少的工具。
11 2
|
10天前
|
缓存 运维 监控
【运维必备知识】Linux系统平均负载与top、uptime命令详解
系统平均负载是衡量Linux服务器性能的关键指标之一。通过使用 `top`和 `uptime`命令,可以实时监控系统的负载情况,帮助运维人员及时发现并解决潜在问题。理解这些工具的输出和意义是确保系统稳定运行的基础。希望本文对Linux系统平均负载及相关命令的详细解析能帮助您更好地进行系统运维和性能优化。
28 3