Linux系统学习之正则表达式

简介: 一、基础的正则表达式1."."(一个点)符号点符号用于U匹配除换行符号之外的任意一个字符。例如:r.t可以匹配rot、rut,但是不能匹配root,但如果使用r..t,就可以匹配root、ruut、r  t(中间是两个空格)等。

一、基础的正则表达式

1."."(一个点)符号

点符号用于U匹配除换行符号之外的任意一个字符。例如:r.t可以匹配rot、rut,但是不能匹配root,但如果使用r..t,就可以匹配root、ruut、r  t(中间是两个空格)等。

2.“*”符号

"*"号用于匹配前一个字符0次或任意多次,比如ab*,可以匹配a、ab、abb等。"*"号经常和"."符号加在一起使用。比如".*"代表任意长度的不包含换行的字符。

3.“{n,m\}"符号

虽然"*"可用于重复匹配前一个字符,但却不能精确地控制匹配的重复次数,使用"\{n,m\}"符号则能更加灵活地控制字符的重复次数,典型的有以下三种形式:

\{n\} 匹配前面的字符n次。下列匹配的是包含root的行(r和t中包含两个o)

[root@Cfhost-170820-UCNK ~]# grep 'ro\{2\}t' /etc/passwd
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin

  

\{n,\}匹配前面的字符至少n次以上(含n次)

[root@Cfhost-170820-UCNK ~]# grep 'ro\{0,\}t' /etc/passwd
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin
vcsa:x:69:69:virtual console memory owner:/dev:/sbin/nologin

\{n,m\}匹配前面的字符n到m次

4."^"这个符号位于数字键盘6的上面,又称尖角号。这个符号用于匹配开头的字符。比如说"^root" 匹配的是以字母root开始的行

[root@Cfhost-170820-UCNK ~]# grep '^root' /etc/passwd
root:x:0:0:root:/root:/bin/bash

 5.“$"符号

和上面的尖角号相对,“$"用于匹配尾部,比如说"abc$"代表的是以abc结尾的行。如果是"^$"则代表该行为空,因为^和$间什么都没有。下例匹配的是以r开头,中间有一串任意字符,以h结尾

[root@Cfhost-170820-UCNK ~]# grep '^r.*h$' /etc/passwd
root:x:0:0:root:/root:/bin/bash

6."[]"符号

这是一对方括号,用于匹配方括号出现的任一字符。比如说单选题的答案,可能是ABCD选项中的任意一个,正则表达式表示的就是[ABCD].如果遇到比较大范围的匹配,比如说要匹配任意一个大写字符,就需要使用"-"号做范围限定,写成[A-Z],要匹配所有字母则写成[A-Za-z].一定要注意,这里的”-“的作用不是充当一个字符。

如果是要匹配不是大写字母A、B、C、D的字符又该怎么写?还记得上面的"^"号吗?如果这个符号出现在[]中,则代表取反,也就是不是的意思。那这里的写法就是[^A-D],事情变得有点复杂了。

  这里举个例子,看如何匹配手机号。手机号是11位连续的数字,第一位一定是1,所有表示"^1";第二位有可能是3(移动)或8(联通),表示为"[38]";后面连续9个任意数字,表示为

"[0-9]\{9\}";所以整个表达式应该写为"^[38][0-9]\{9\}"

7."\"符号|
假设有一个固定电话号码021-88888888,当然也可以写成 021 88888888(区号和电话号码之间用空格隔开),它们的不同之处就是区号和电话号码之间使用的符号不同,一个是
“-”,一个是空格。那么,对于这个电话号码要怎么匹配呢?很容易地想起应该使用"[]"来匹配。但是这么写:[-]是不对的,因为"-"放到"[]"中有特别含义。为了表示其作为一个字符的本意,就要使用"\"符了,这个符号代表转义字符,我们可以对很多特殊的字符进行“转义”,让它只代表字符本身,因此这里的写法就是[\ \-].

再举个例子,之前我们了解到".*"代表的是任意长度的不包括换行的重复字符。但是如果想要匹配任意长度的点号呢?这时我们用转义字符就对了:“\.*"。如果想要对”\"符号进行转义,就可以这样写:“\\"。

8."\<"符号和"\>"符号

这两个符号分别用于界定单词的左边界和右边界。birushuo"\<hello"用于匹配以”helo"开头的单词;而"hell\>"则用于匹配以"hello"结尾的单词。还可以2使用它们的组合“\<\>"用于精确匹配一个字符串。所以”\<hello\>"可精确匹配单词"hello",而不是helloworld等。如下所示:

[root@Cfhost-170820-UCNK ~]# echo "hello" | grep '\<hello\>'
hello
[root@Cfhost-170820-UCNK ~]# echo "hellod" | grep '\<hello\>'
#//没有输出,表示匹配不成功

9.”\d"符号

匹配一个数字,等价于[0-9],使用grep匹配这种正则表达式时,可能会遇到无法匹配的问题,示例如下:

[root@Cfhost-170820-UCNK ~]# echo 123 | grep [0-9]
123
[root@Cfhost-170820-UCNK ~]# echo 123 | grep '\d'
#没有输出,表示匹配不成功,为什么呢?
#这是因为"\d"是一种Per1兼容模式的表达式,又称作PCRE,要想使用这种模式的匹配符,需要加上-P参数

  [root@Cfhost-170820-UCNK ~]# echo 123 | grep -P '\d'
  123

 10.“b"符号

匹配单词的边界,比如"\bhello\b"可精确匹配"hello"单词

[root@Cfhost-170820-UCNK ~]# echo "hello world" |grep '\bhello\b'
hello world
[root@Cfhost-170820-UCNK ~]# echo "helloworld" |grep '\bhello\b'
#这里没有匹配

11."\B"符号

匹配非单词的边界,比如hello\B可以匹配"helloworld“中的"hello"

[root@Cfhost-170820-UCNK ~]# echo "helloworld" |grep 'hello\B'
helloworld

12."\w"符号

匹配字母、数字、下划线,等价于[A-Za-z0-9]

[root@Cfhost-170820-UCNK ~]# echo "a" | grep '\w'
a
[root@Cfhost-170820-UCNK ~]# echo "\\" | grep '\w'

14."\n"符号

匹配一个换行符

15.”\r"符号

匹配一个回车符

16."\t"符号

匹配一个制表符

17."\f"符号

匹配一个换页符

18."\s"符号

匹配任何空白字符

19."\S"符号

匹配任何非空白字符

二、扩展的正则表达式

“?”符号

"?"符号用于匹配前一个字符0次或1次,所以"ro?t"仅能匹配rot或rt

“+”符号

"+"符号用于匹配前一个字符1次以上,所以"ro+t"就可以匹配rot、root等

"|"符号

"|" 符号是"或"的意思,即多种可能的罗列,彼此间是一种分支关系。比如说有些地区固定电话的区号是4位数,有些地方却是3位数,这样针对不同的区号就有不同的固定电话的表示如:

#区号是3位的固定电话的正则表达式方式

^0[0-9]\{2\}-[0-9]\{8\}

#区号是4位的固定电话的正则表达式方式

^0[0-9]\{3\}-[0-9]\{8\}

#两种区号的固定电话号码可以如下写:

^0[0-9]\{2,3}-[0-9]\{8\}

#使用"|"符号业可以,但是显然比上面的方式麻烦

^0[0-9]\{2\}-[0-9]\{8\}|^0[0-9]\{3\}-[0-9]\{8\}

#"()"符号

"()符号通常需要和"|"符号联合使用,用于枚举一系列可替换的字符。比如说固定电话的区号和电话号码之间,可能用"-"符号或者用一个空格连接,用于匹配的正则表达式如下:

^0[0-9]\{2,3\}(-1)[0-9]\{8\}

^0[0-9]\{2,3\}[\ \-] [0-9]\{8\}

虽然以上两种写法没有本质的不同,因为"()"和"|"可以和"[]"相互混用,但是在某些场景下,"()"和"|"可以做的更多,比如说像hard、hold或hood等这类开头和结尾的字母都一样的单词,要匹配这些就必须使用"()"和"|"了。如下所示:

h(ar|oo|ol)d

 三、通配符

实际上,通配符是一种特殊的语句·1,主要包含"*"号和"?"号(还有"{}"、“^"、”!“)。主要用来模糊搜索文件,使用它来代替一个或多个真正的字符,尤其是在不知道或者不确定完整的文件名时,用来匹配符合条件的文件。

”*“符号:

这里的*就是提到的第一个通配符,代表0个或多个字符。

”?“符号

如果要列出以字母A开头、但是只有两个字母的文件名、以.doc结尾的文件,就需要使用"?"了。当它作为通配符使用时,代表的是任意一个字符。

”{}"符号:

"{}"可拥有匹配所有括号内包含的以逗号隔开的字符。

目录
相关文章
|
3天前
|
存储 IDE Linux
零基础保姆级教程!手把手教你免费玩转Linux CentOS安装+学习环境搭建(附避坑指南)
本文详细介绍了在VMware虚拟机中安装CentOS 6.8的全过程。首先,需确保已安装VMware并开启V-CPU虚拟化功能,可通过BIOS设置或使用LeoMoon CPU-V工具检测。接着,下载CentOS镜像文件,并在VMware中新建虚拟机,配置CPU、内存、硬盘等参数。最后,加载ISO镜像启动虚拟机,按照提示完成CentOS的安装,包括语言、键盘、存储方式、地区、密码设置及硬盘分区等步骤。安装完成后,以root用户登录即可进入系统桌面,开始学习Linux命令和操作。
39 12
零基础保姆级教程!手把手教你免费玩转Linux CentOS安装+学习环境搭建(附避坑指南)
|
1月前
|
Linux
Linux系统之whereis命令的基本使用
Linux系统之whereis命令的基本使用
73 24
Linux系统之whereis命令的基本使用
|
2月前
|
缓存 安全 Linux
Linux系统查看操作系统版本信息、CPU信息、模块信息
在Linux系统中,常用命令可帮助用户查看操作系统版本、CPU信息和模块信息
153 23
|
3月前
|
存储 监控 Linux
嵌入式Linux系统编程 — 5.3 times、clock函数获取进程时间
在嵌入式Linux系统编程中,`times`和 `clock`函数是获取进程时间的两个重要工具。`times`函数提供了更详细的进程和子进程时间信息,而 `clock`函数则提供了更简单的处理器时间获取方法。根据具体需求选择合适的函数,可以更有效地进行性能分析和资源管理。通过本文的介绍,希望能帮助您更好地理解和使用这两个函数,提高嵌入式系统编程的效率和效果。
135 13
|
3月前
|
存储 缓存 监控
Linux缓存管理:如何安全地清理系统缓存
在Linux系统中,内存管理至关重要。本文详细介绍了如何安全地清理系统缓存,特别是通过使用`/proc/sys/vm/drop_caches`接口。内容包括清理缓存的原因、步骤、注意事项和最佳实践,帮助你在必要时优化系统性能。
299 78
|
3月前
|
Ubuntu Linux C++
Win10系统上直接使用linux子系统教程(仅需五步!超简单,快速上手)
本文介绍了如何在Windows 10上安装并使用Linux子系统。首先,通过应用商店安装Windows Terminal和Linux系统(如Ubuntu)。接着,在控制面板中启用“适用于Linux的Windows子系统”并重启电脑。最后,在Windows Terminal中选择安装的Linux系统即可开始使用。文中还提供了注意事项和进一步配置的链接。
96 0
|
3月前
|
Linux Shell 网络安全
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
本指南介绍如何利用 HTA 文件和 Metasploit 框架进行渗透测试。通过创建反向 shell、生成 HTA 文件、设置 HTTP 服务器和发送文件,最终实现对目标系统的控制。适用于教育目的,需合法授权。
103 9
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
|
3月前
|
存储 Oracle 安全
服务器数据恢复—LINUX系统删除/格式化的数据恢复流程
Linux操作系统是世界上流行的操作系统之一,被广泛用于服务器、个人电脑、移动设备和嵌入式系统。Linux系统下数据被误删除或者误格式化的问题非常普遍。下面北亚企安数据恢复工程师简单聊一下基于linux的文件系统(EXT2/EXT3/EXT4/Reiserfs/Xfs) 下删除或者格式化的数据恢复流程和可行性。
|
4月前
|
Ubuntu Linux 网络安全
linux系统ubuntu中在命令行中打开图形界面的文件夹
在Ubuntu系统中,通过命令行打开图形界面的文件夹是一个高效且实用的操作。无论是使用Nautilus、Dolphin还是Thunar,都可以根据具体桌面环境选择合适的文件管理器。通过上述命令和方法,可以简化日常工作,提高效率。同时,解决权限问题和图形界面问题也能确保操作的顺利进行。掌握这些技巧,可以使Linux操作更加便捷和灵活。
128 3
|
4月前
|
Linux
在 Linux 系统中,`find` 命令
在 Linux 系统中,`find` 命令
126 56