代碼如下:
代碼如下:#! /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
附:常用的shell正則表達式
代碼如下:
^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] 匹配中文字符的正則表達式
[^/x00-/xff] 匹配雙字節字符(包括漢字在內)
/n[/s| ]*/r 匹配空行的正則表達式
/<(.*)>.*<///1>|<(.*) //>/ 匹配HTML標記的正則表達式
(^/s*)|(/s*$) 匹配首尾空格的正則表達式
/w+([-+.]/w+)*@/w+([-.]/w+)*/./w+([-.]/w+)* 匹配Email地址的正則表達式
^[a-zA-z]+://(//w+(-//w+)*)(//.(//w+(-//w+)*))*(//?//S*)?$ 匹配網址URL的正則表達式
^[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號
新聞熱點
疑難解答