正则表达式

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
正则表达式
    正则表达式(regular expression,RE) 是一种字符模式,用于在查找过程中匹配指定的字符。
    在大多数程序里,正则表达式都被置于两个斜杠之间;例如/l[oO]ve/就是由正斜杠界定的正则表达式
    它将匹配被查找的行中任何位置出现的相同模式。在正则表达式中,元字符是最重要的概念。
    举例
        匹配数字:^[0-9]+$
        匹配email:[a-z0-9_]+@[a-z0-9]+\.[a-z]+
        匹配IP:[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}
                
                [[:digit:]]{1,3}\.[[:digit:]]{1,3}\.[[:digit:]]{1,3}\.[[:digit:]]{1,3}
 
元字符
    定义:元字符是这样一种字符,它们表达的是不同于字面本身的含义
    shell元字符(也称为通配符) 由shell来解析,如rm -rf *.pdf,元字符*shell将其解析为任意多个字符
    正则表达式元字符  由各种执行模式匹配操作的程序来解析,比如vigrepsedawk
 
    vim示例
    :1,$ s/tom/David/g  #把tom替换
    :1,$ s/\<[Tt]om\>/David/g #tom Tom都会替换

  

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
正则表达式元字符
#基本正则表达式元字符
元字符     功能      示例
============================================================================
^           行首定位符           ^love
$           行尾定位符           love$
.           匹配任意单个字符    l..e
*           匹配前导符0到多次   ab*love
.*          任意多个字符
[]          匹配指定范围内的一个字符    [iL]ove
[ - ]       匹配指定范围内的一个字符    [a-z0-9]ove
[^]         匹配不在指定组内的字符     [^a-z0-9]ove
\           用来转义元字符     love\.
\<           词首定位符           \<love       #类似于\b '\<love\>'='\blove\b'
\>           词尾定位符           love\>
\(..\)\     匹配稍后使用的字符的标签    :% s/172.16.130.1/172.16.130.5/
                                        :% s/\(172.16.130.\)1/\15/
                                        :% s/\(172.\)\(16.\)1/\1\25/
x\{m\}      字符x重复出现m次   o\{5\}
x\{m,\}     字符x重复出现m次以上     o\{5,\}
x\{m,n\}    字符x重复出现m次到n次        o\{5,10\}
 
======================扩展元字符=============================================
+           匹配一个或多个前导字符     [a-z]+ove
?           匹配零个或一个前导字符     lo?ve
a|b         匹配a或b                   love|hate
()          组字符                    
(..)(..)\1\2标签匹配字段              (love)able\1er
x{m}        字符x重复m次             o{5}
x{m,}       字符x重复m次以上           o{5,}
x{m,n}      字符x重复m次到n次          o{5,10}
 
=====================POSIX字符类=============================================
表达式         功能              示例
[:alnum:]       字母与数字字符     [[:alnum:]]+     #类似\w 'L\wve';\W 字母与数字之外的字符,称为非字符 '\love\W+'
[:alpha:]       字母字符(包括大小写)[[:alpha:]]{4}
[:blank:]       空格与制表符      [[:blank:]]*
[:digit:]       数字字母            [[:digit:]]?
[:lower:]       小写字母            [[:lower:]]{5,}
[:upper:]       大写字母            [[:upper:]]+
[:punct:]       标点符号            [[:punct:]]
[:space:]       包括换行符、回车等在内的所有空白    [[:space:]]+
 
#正则匹配示例:vim
/love/
/^love/
/love$/
/l.ve/
/lo*ve/
/[Li]ove/
/love[a-z]/
/love[^a-zA-Z0-9]/
/.*/
/^$/  #空行 等同于/^[ \t]*$/
/^[A-Z]..$/
/^[A-Z][a-z]*3[0-5]/
/[a-z]*\./
#注释行
/^#/
/^[ \t]*#/

  

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
grep家族
    grep: 在文件中全局查找指定的正则表达式;grep也可使用扩展集中的字符,仅需要对这些元字符前置一个反斜线
    egrep: 扩展的grep ,支持更多的正则表达式元字符 ;或者grep -E 使用扩展元字符集
    fgrep: 固定grep,也被称作快速,它按字面解释所有字符
 
#grep命令格式
#grep [选项] pattern filename1 filename2
#grep 'Tom' /etc/passwd
#   找到: grep返回退出状态为0
#   没找到:    grep返回的退出状态为1
#   找不到指定文件:grep返回的退出状态为2
 
#grep选项
-i      #忽略大小写
-l      #列出匹配行所在的文件名
-n      #每行加上行号
-c      #显示匹配成功的行数
-q      #静默
-v      #反向查找,只显示不匹配的行
-R,-r   #递归针对目录
-B      #前几行
-A      #后几行
-C      #前后几行

  

posted @   smatterer  阅读(25)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!
点击右上角即可分享
微信分享提示