正则表达式

正则表达式

正则表达式匹配的的是文本内容,

由一类特殊字符以及文本字符所编写的一个模式,模式又来匹配文件当中内容(字符).

检验我们输入的内容是否满足规定,格式,长度等等要求

主要用来匹配文本内容,命令的结果也可以用正则表达式

通配符:只用能用于匹配文件名和目录名,不能匹配文件的内容和命令结果

表达式

一般和grep配合使用

基本正则 元字符匹配

. 任意单个字符,也可以是一个汉字

复制代码
ls | grep '.'

\ 转义符

复制代码
ls | grep '\.'	还是所搜点号

匹配指定范围内的任意单个字符或者数字

复制代码
grep '[a-b]' xy102.txt

匹配空格

复制代码
grep '[ ]' xy102.txt

\^ 取反

复制代码
grep '^a' xy102.txt  	除了a之外都显示

^#

复制代码
grep '^#' xy102.txt		以#号开头的

^$ 空行

复制代码
grep '^$' xy102.txt		

*匹配前面的字符任意次,0次也算

贪婪模式,尽可能的匹配

但goo,最多只能再多一位

例如grep 'gooi8*'

再多一位就不能了 grep 'gooi88*'

复制代码
echo gggle | grep 'g*'
echo ggle | grep '1*gle'

.* 匹配前面的任意字符,至少要有1次,匹配所有,但至少要有一个

复制代码
echo ggle | grep '2.*gle'	以2开头的gle,至少得有1个

? 匹配前面的字符0次或者1次,可有可无

复制代码
echo gole | grep 'o\?le'

\+ 匹配的字符至少要有一次

复制代码
echo gole | grep 'o\+le'

\{n\} 匹配前面的字符=n次,或者小于n,不能大于n,而且前面的字符要连续出现

复制代码
grep 'a\{5\}' test1.txt

\{m,n\} 匹配前面的字符至少m次,至多n次,也需要是连续出现,超出的不在匹配范围

复制代码
grep 'a\{2,5\}' test1.txt

\{,n\} 匹配前面的字符最多N次

\{,n\} 匹配前面的字符最少N次

扩展正则

1、显示/etc/passwd中以sh结尾的行;

cat /etc/passwd |grep -E '(sh)$'

2、查找/etc/inittab中含有"以s开头,并以d结尾的单词"模式的行;

cat /etc/inittab | grep -E '\bsa-zA-Z*d\b'

3、查找ifconfig命令结果中的1-255之间的整数;

ifconfig|grep -E '(\b10-90-9\b)|(\b20-90-9\b)|(\b0-90-9\b)|(\b1-9\b)'

4、在/etc/passwd中取出默认shell为bash的行;

cat /etc/passwd|grep -E 'bash$'

5、高亮显示passwd文件中冒号,及其两侧的字符

cat /etc/passwd|grep -E '.?😗:.?'

片转存中...(img-n2dmPNaM-1719234125285)]

5、高亮显示passwd文件中冒号,及其两侧的字符

cat /etc/passwd|grep -E '.?😗:.?'

外链图片转存中...(img-aYlRvxQs-1719234125285)

相关推荐
Sokach10158 小时前
Linux Shell 脚本从零到能用:一个新手的一天学习总结
linux
AlfredZhao1 天前
Docker 容器时区不对,`timedatectl` 不存在怎么办?
linux·timezone
Jim6001 天前
【吃透 MySQL InnoDB连载】第 1 章・解密线上数据库高频故障
mysql
GreatSQL1 天前
gt-checksum v4.0.0 新功能解读系列文章(4):SSL 加密连接——数据校验传输安全再升级
mysql
zzzzzz3102 天前
9K Star 炸裂开源!这个 C 语言写的代码知识图谱,把 Linux 内核索引压缩到了 3 分钟
linux·服务器·sql
XIAOHEZIcode2 天前
Linux系统鼠标偏移常见原因以及修复方案
linux·运维·游戏
A小辣椒4 天前
TShark:Wireshark CLI 功能
linux
云技纵横4 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
沉默王二4 天前
面试官:RAG 不用向量数据库,用 MySQL 硬扛?我:100 万向量不是很轻松?
mysql·面试·ai编程