正则表达式

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

作用:校验我们输入的内容是否满足规定,格式,长度等等要求。

主要用来匹配文本内容以及命令的结果。

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

正则表示有两种:

基本正则表达式

元字符(字符匹配)

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

\ 转义符 恢复其本义

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

[^] 取反 ^不加[] 匹配开头的的字符

除了d以外显示所有的内容。

匹配字符出现的次数:

”*“ 匹配前面的字符任意次,0次也可以。贪婪模式,尽可能的匹配。

”.*“ 匹配前面的任意字符,至少要有一次,匹配所有。

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

”\ + “ 匹配前面的字符,至少要有一次。

\ {n \ } 匹配前面的字符等于n次,可以小于n,但是不能大于n,而且前面的字符必要连续出现。

\ {m,n \ } 匹配前面的字符至少m次,最多n次。必须是连续出现,超出不在匹配范围。

位置锚定:

^ :以什么为开头 行首锚定

$: 以什么为结尾 行尾锚定

^$ : 空行

\ <或者\b 词首锚定,匹配单词的左侧(连续的数字,字母,下划线都算单词内部)

\ >或者\b 词尾锚定,匹配单词的右侧(连续的数字,字母,下划线都算单词内部)

区别

\broot\b : 匹配整个单词,空格隔开的也算整个单词

^root$ : 整个一行只有这个单词

分组和逻辑关系

分组:()

或者: \ |

扩展正则表达式

把基本正则表达式前面的\删除就是扩展正则表达式

”*“ 匹配前面的字符任意次,0次也可以。贪婪模式,尽可能的匹配。

”.*“ 匹配前面的任意字符,至少要有一次,匹配所有。

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

”+ “ 匹配前面的字符,至少要有一次,

{n } 匹配前面的字符等于n次,可以小于n,但是不能大于n,而且前面的字符必要连续出现。

{m,n } 匹配前面的字符至少m次,最多n次。必须是连续出现,超出不在匹配范围。

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

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

位置锚定:

^ :以什么为开头 行首锚定

$: 以什么为结尾 行尾锚定

^$ : 空行

【\ <或者\b 词首锚定,匹配单词的左侧(连续的数字,字母,下划线都算单词内部)】

【\ >或者\b 词尾锚定,匹配单词的右侧(连续的数字,字母,下划线都算单词内部)】

唯一的区别就是词首词尾锚定\b要加\

扩展正则表达式命令行:grep -E或者egrep 都可以

  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值