【编程通识】正则表达式
??正則表達式是對字符串操作的一種邏輯公式,就是用事先定義好的一些特定字符、及這些特定字符的組合,組成一個“規則字符串”,這個“規則字符串”用來表達對字符串的一種過濾邏輯,常被用來檢索、替換那些符合某個模式(規則)的文本。
?
入門
輸入code即可匹配所有包含code的字符串
字符串[ ]允許匹配其內任一字符,例: [Ab3] 允許匹配 A 或 b 或 3
連字符-代表區間,例:[0-9]允許匹配任何數字、[a-zA-Z]允許匹配任何小寫或大寫字母
轉義符\用于匹配 [、] 、- 、(、) 等特殊字符
取反符^用于匹配不符合字符組描述的數據,例:[^0-9]允許匹配任何非數字字符;[^a]匹配任何不是a的字符
取或符|用于匹配符合其左邊、右邊任一條件的字符(串)
?
?
快捷方式
\w允許匹配任意字母、數字、下劃線
\d允許匹配任意數字
\s允許匹配空格、tab、換行
\b允許匹配單詞、數字邊界,例:\blow\b 匹配 low-er、low.er,不匹配單詞 lower;\b\d\b匹配1、2,不匹配12
快捷方式取反大寫即可,例:\D匹配所有非數字字符、\W匹配所有特殊字符
^指定的是一個字符串的開始,例:^a匹配所有以a開頭的字符串
$指定的是一個字符串的結束,例:a$匹配所有以a結束的字符串
.允許匹配除換行符外的任意字符,且只能在 [ ]以外使用
?表示前邊字符、字符組或其他基本單元可出現或不出現,例:[a-z]?1匹配小寫字母+1或單獨一個1;.?匹配任意字符
?
?
匹配多個數據
{N}連續匹配N次,例:code{N}匹配連續出現N次code的字符串
{M,N}連續匹配M~N次,優先匹配連續出現N次的(貪婪)
{M,N}?連續匹配M~N次,優先匹配連續出現M次的(懶惰)
{M,}連續匹配大于等于M次
+連續匹配大于等于1次,相當于{1,},例:f.+匹配以f開頭的字符串
+?連續匹配大于等于1次,優先匹配出現次數少的(懶惰)
\* 連續匹配大于等于0次,相當于{0,},例:^http.*/$匹配以http開頭且以/結尾的任意字符串
?連續匹配大于等于0次,優先匹配出現次數少的(懶惰)
()括號內為子表達式,視為匹配的基本單元
?
?
練習網站、測試網站
《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀總結
以上是生活随笔為你收集整理的【编程通识】正则表达式的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【移动通信】4G LTE帧结构
- 下一篇: 【编程通识】PlantUML绘制时序图样