正则表达式 正则表达式(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将其解析为任意多个字符 正则表达式元字符 由各种执行模式匹配操作的程序来解析,比如vi、grep、sed、awk vim示例 :1,$ s/tom/David/g #把tom替换 :1,$ s/\<[Tt]om\>/David/g #tom Tom都会替换
正则表达式元字符 #基本正则表达式元字符 元字符 功能 示例 ============================================================================ ^ 行首定位符 ^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]*#/
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 #前后几行
标签:字符,grep,love,正则表达式,匹配,元字符 From: https://www.cnblogs.com/smatter/p/16943999.html