前言
本篇的写作目的是通过阅读gun文档,对知识进行进一步的梳理,并配备一些实例,便于自己后期的使用,如果文章有错误欢迎评论区指出。
由来
正则表达式由自由软件grep、awk、sed进一步发展而来,包含BRE(Basic Regular Expresion)、ERE(Extend Regular Expresion)、PRE(Perl Reglar Expression),正文内容以BRE展开,对于BRE和ERE的区别
必备工具
regexp在线测试(没有VPN会很慢)
regexp根据问题在线练习
正文
匹配次数控制
. 匹配任意一个字符
* 匹配前面表达式`0次`或`多次`
+ 匹配前面表达式`一次`或`多次`
{n} 匹配n次
{n,} 匹配至少n次
{,m} 匹配至多m次
{n,m} 匹配x次(n<=x<=m)
匹配集合
[] 匹配方括号中的任意一个,例如[abc] 会匹配a或者b或者c
BRE提供了一些常用的匹配集合
[:lower:] 小写字母
[:upper:] 大写字母
[:alpha:] 包含以上两个
[:digit:] 数字
[:alnum:] 包含以上两个
[:blank:] tab和space
[:punct:] 符号:! " # $ % & ' ( ) * + , - . / : ; < = > ? @ [ \ ] ^ _ ` { | } ~.
[:xdigit:] 16进制:0 1 2 3 4 5 6 7 8 9 A B C D E F a b c d e f.
特征标群
普通使用
用于匹配一个整体
// 匹配abc 0次或多次,例如可以匹配 abc,abcabc
(abc)*
|
// 可以匹配 ad,bd,cd
(a|b|c)d
反斜线和特殊表达式
反斜线用作转意
`\b` 匹配单词时单词首尾要加这个
`\B` 非单词边界
`\<` 单词开始
`\>` 单词结束
`\w` 等价于‘[_[:alnum:]]’.
`\W` 等价于[^_[:alnum:]].
`\s` 等价于[[:space:]].
`\S` 等价于[^[:space:]]
行标志
^ 行首标志
$ 行尾标志
断言(待完善)
正先行断言
后面成立=》选中前面 (?=)
负先行断言
后面不成立=》选中前面 ?!
正后发断言
前面成立=>选中后面 ?<=
负后发断言
前面不成立=》选中后面 ?<!
本文旨在通过梳理gun文档,深入理解Linux中的正则表达式,包括BRE的基本概念。内容涵盖匹配次数控制、匹配集合、特征标群、反斜线和特殊表达式、行标志以及各种断言的使用,旨在提供实例辅助学习。
1万+

被折叠的 条评论
为什么被折叠?



