shell也可以使用正則分組捕獲,不過不能使用 $1或\1這樣的形式來捕獲分組,可以通過數組${BASH_REMATCH}來獲得,如${BASH_REMATCH[1]},${BASH_REMATCH[N]}
下面以ip="121.0.2.2"為例,shell指令碼代碼如下(當然,你要做成更通用互動指令碼,可以通過expect來實現):
#!/bin/bash
ip="121.0.2.2"
if [[ $ip =~ ^([0-9]{1,2}|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\.([0-9]{1,2}|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\.([0-9]{1,2}|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\.([0-9]{1,2}|1[0-9][0-9]|2[0-4][0-9]|25[0-5])$ ]]
then
echo "Match"
echo ${BASH_REMATCH[1]}
echo ${BASH_REMATCH[2]}
echo ${BASH_REMATCH[3]}
echo ${BASH_REMATCH[4]}
else
echo "Not match"
fi
shell指令碼正則匹配檔案中的Email並記錄到檔案
#! /bin/bash
function read_file(){
for line in `cat $1`
do
if [ `echo $line |grep "^[a-zA-Z0-9_-]*@[A-Za-z_-]*\.[a-zA-Z_-]*$"` ];then
echo $line >> result.txt
else
echo "---" >> result.txt
fi
done
}
#eg
read_file a.txt
常用的shellRegex
^USER$ 匹配只包含USER的行
[tty]$ 匹配以tty結尾的行
\. 匹配帶句點的行
^d..x..x..x 匹配使用者、使用者組及其他使用者群組成員有可執行許可權的目錄
^[^l] 匹配排除關聯目錄的目錄列表
[.*0] 匹配0之前或之後加任一字元
[^$] 匹配空行
[^.*$] 匹配匹配行中任一字元串
^......$ 匹配包括6個字元的行
[a-zA-Z] 匹配任意單字元
[a-z][a-z]* 匹配至少一個小寫字母
[^0-9\$] 匹配非數字或美元標識
[^0-0A-Za-z] 匹配非數字或字母
De..ce 匹配前兩個字母為De,後跟兩個任一字元,最後為ce
[1..9] 匹配匹配1到9
^.$ 匹配僅有一個字元的行
^\.[0-9][0-9] 匹配以一個句點和兩個數字開始的行
'"Device"' 匹配單詞device
De[Vv]ice\. 匹配單詞Device或deVice
[0-9]\{2\}-[0-9]\{2\}-[0-9]\{4\} 匹配日期格式dd-mm-yyyy
[^.*$] 匹配匹配任意行
^[1-9]\d{5}$ 匹配郵遞區號
((\+?[0-9]{2,4}\-[0-9]{3,4}\-)|([0-9]{3,4}\-))?([0-9]{7,8})(\-[0-9]+)?$/ 匹配電話號碼
((\(\d{2,3}\))|(\d{3}\-))?13\d{9}$ 匹配手機號碼
(d{1,2}|1dd|2[0-4]d|25[0-5]).(d{1,2}|1dd|2[0-4]d|25[0-5]).(d{1,2}|1dd|2[0-4]d|25[0-5]).(d{1,2}|1dd|2[0-4]d|25[0-5])$” 匹配IP地址
[\u4e00-\u9fa5] 匹配中文字元的Regex
[^\x00-\xff] 匹配雙位元組字元(包括漢字在內)
\n[\s| ]*\r 匹配空行的Regex
/<(.*)>.*<\/\1>|<(.*) \/>/ 匹配HTML標記的Regex
(^\s*)|(\s*$) 匹配首尾空格的Regex
\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)* 匹配Email地址的Regex
^[a-zA-z]+://(\\w+(-\\w+)*)(\\.(\\w+(-\\w+)*))*(\\?\\S*)?$ 匹配網址URL的Regex
^[a-zA-Z][a-zA-Z0-9_]{4,15}$ 匹配帳號是否合法(字母開頭,允許5-16位元組,允許字母數字底線)
(\d{3}-|\d{4}-)?(\d{8}|\d{7})? 匹配國內電話號碼
^[1-9]*[1-9][0-9]*$ 匹配騰訊QQ號