正規表示式: regexp, regular express ion
正規表示式分為兩類:
basic regexp (基本正規表示式)
extended regexp (擴 展正規表示式)
//元字元
. //任意單個字元
//匹配指定範圍內的任意單個字元
[^] //匹配指定範圍外的任意單個字元
//匹配次數(貪婪模式)
* //匹配其前面的人以單個字元任意次
.* //任意長度的任意字元
\? //匹配其前面的任意字元1次或0次
\+ //匹配其前面的任意單個字元至少一次
\ //匹配其前面的人以單個字元至少m次,至多n次
//位置描述
^ //錨點行首,此字元後面的任意單個字元必須出現在行首
$ //錨定行尾,此字元後面的任意單個字元必須出現在行尾
^$ //空白行
\《或\b //錨定詞首,此字元後面的任意單個字元必須作為單詞首部出現
\>或\b //錨定詞尾,此字元後面的任意單個字元必須作為單詞尾部出現
//分組
\(\)
例:\(ab\)*
//後向引用
\1 //引用第乙個左括號以及與之對應的右括號所包括的所有內容
\2 //引用第二個左括號以及與之對應的右括號所包含的所有內容
//字元匹配
. //任意單個字元
//匹配指定範圍內的任意單個字元
[^] //匹配指定範圍外的任意單個字元
//匹配次數(貪婪模式)
* //匹配其前面的人以單個字元任意次
.* //任意長度的任意字元
\? //匹配其前面的任意字元1次或0次
\+ //匹配其前面的任意單個字元至少一次
\ //匹配其前面的人以單個字元至少m次,至多n次
//位置描述
^ //錨點行首,此字元後面的任意單個字元必須出現在行首
$ //錨定行尾,此字元後面的任意單個字元必須出現在行尾
^$ //空白行
\《或\b //錨定詞首,此字元後面的任意單個字元必須作為單詞首部出現
\>或\b //錨定詞尾,此字元後面的任意單個字元必須作為單詞尾部出現
//分組
\(\)
//分組
() //分組
\1,\2,\3,……
例:(ab)*
//後向引用
\1 //引用第乙個左括號以及與之對應的右括號所包括的所有內容
\2 //引用第二個左括號以及與之對應的右括號所包含的所有內容
//或者
| //or預設匹配|的整個左側或整個右側的內容
//例: c|cat表示c或者cat,要想表示cat或者cat則需要使用分組,5如(c(c)at
4.例項
[root@ymm-xiaokeai ~]
# ls | grep '.' //匹配任意單個字元
110.txt
11.txt
1231.sh
1.txt
2020-03-18.log
[root@ymm-xiaokeai ~]
# ls | grep '[ab]' //匹配a和b兩個字元
abcd
anaconda-ks.cfg
backup.tar.gz
db-backup.sh
manman.repo
program
suan.sh
watched
yang
[root@ymm-xiaokeai ~]
# ls | grep '[^a]' //除a以外的所有字元
110.txt
11.txt
1231.sh
1.txt
2020-03-18.log
22.txt
33.txt
[root@ymm-xiaokeai ~]
# ls | grep '1*' //匹配所有1
110.txt
11.txt
1231.sh
正規表示式 正規表示式 總結
非負整數 d 正整數 0 9 1 9 0 9 非正整數 d 0 負整數 0 9 1 9 0 9 整數 d 非負浮點數 d d 正浮點數 0 9 0 9 1 9 0 9 0 9 1 9 0 9 0 9 0 9 1 9 0 9 非正浮點數 d d 0 0 負浮點數 正浮點數正則式 英文本串 a za z...
正規表示式 表示式
網域名稱 a za z0 9 a za z0 9 a za z0 9 a za z0 9 interneturl a za z s 或 http w w w 手機號碼 13 0 9 14 5 7 15 0 1 2 3 5 6 7 8 9 18 0 1 2 3 5 6 7 8 9 d 號碼 x x x...
Linux正規表示式 編寫正規表示式
為了所有實用化的用途,你可以通過使用程式產生正確的結果。然而,並不意味著程式總是如你所願的那樣正確地工作。多數情況下,如果程式不能產生想要的輸出,可以斷定真正的問題 排除輸入或語法錯誤 在於如何描述想要的東西。換句話說,應該考慮糾正問題的地方是描述想要的結果的表示式。表示式不完整或者公式表示得不正確...