shell编程--正则表达式
正则表达式
正则表达式都被置于两个正斜杠之间;如/l[oO]ve/
示例
匹配数字的脚本,用户输入创建账号的数量
语法: [[ ^[0-9]+$ ]]
表示必须输入数字
#!/bin/bash
while :
do
read -p "输入数字:" num
if [[ $num =~ ^[0-9]+$ ]]
then
echo "再见"
exit
else
echo "重新输入"
fi
done
#!/bin/bash
read -p "你好,请输入姓名:" name
while :
do
read -p "你是傻子吗,请输入 是:" num
if [ $num = "是"]
then
echo "大傻子,$name,再见"
exit
else
echo "重新输入"
fi
done
元字符
定义
元字符表达不同于字面本身的含义
分类
基本正则
^ 行首定位符
# cat /etc/passwd
#找出root
grep root /etc/passwd
#找出行首为root
grep "^root" /etc/passwd
$ 行尾定位符
vim 1.txt
i loveyou
love
loveyou
#############################
grep "love$" 1.txt
. 匹配任意单个字符
vim 1.txt
abc
adc
###############################
grep a.c 1.txt
* 匹配前导符0次到多次
vim 1.txt
a
ab
abc
abcd
abcde
abcdef
gg
hh
ii
########################################
grep "abc*" 1.txt
ab
abc
abcd
abcde
abcdef
#ab后面好想有c,好像也没有,c出现0次到多次
grep "abcde*" 1.txt
abcd
abcde
abcdef
#e出现0次到多次
.* 任意多个字符
grep ".*" 1.txt
a
ab
abc
abcd
abcde
abcdef
gg
hh
ii
###################################
为什么*.不可以
*前面没有前导符
[ ] 匹配指定范围内的一个字符
vim 1.txt
love
Love
1love
|ove
#################################################
grep "[lL]ove" 1.txt
love
Love
#取反
grep "[^lL1]ove" 1.txt
|ove
grep "[a-z]ove" 1.txt
love
#####################################################
[0-5][0-9] 匹配00-59
[0-9]匹配0-9
[ - ] 匹配指定范围内的一个字符连续的范围
[0-9]0到9
[a-z]a到z
[A-Z]A到Z
[ ^ ] 匹配不在指定组内的字符
取反
[^0-9]非数字
[^a-z]非小写字母
\ 转义符
grep "l." 1.txt
love
l.ve
\. 转义.
grep "l\." 1.txt
l.ve
用来转义元字符("" '' \)
''强引用
\< 词首定位符
vim 1.txt
iloveyou
love
1love
###############################
grep "\<love" 1.txt
查找以love开头的
\> 词尾定位符
grep "love\>" 1.txt
love
查找以love结尾的
() 匹配稍后使用的字符标签
vim末行模式
iloveyou
loveyou
1love
:1,2 s/\(.*\)/#\1/
#定位1,2行,s///模式,括号得转义,.*匹配所有字符,\1表示第一次括号引用选中的内容,#表示在定位的1,2行前面加#
192.168.1.1
:%s/192.168.1.1/192.168.2.3/
#s///就是替换,把1.1替换为2.3
192.168.2.2
:% s/\(192\)/123\1/
#在192前面加123
x\{m\} 字符x重复几次
love
loove
looove
loooove
looooove
loooooove
grep "o\{3\}" 1.txt
looove
loooove
looooove
loooooove
looooooove
#o重复3符的字符,{}也得转义
x\{m,\} 字符重复出现m次以上
grep "0\{3,\}" 1.txt
x\{m,n\} 字符x重复出啊先m到n次
grep "o\{3,4\}" 1.txt
行首行尾与词首词尾
iloveyou
ilove
loveyou
aaa iloveyou bbb
ccc ilove ddd
eee loveyou fff
####################################
grep "^love" 1.txt
loveyou
grep "\<love" 1.txt
loveyou
eee loveyou fff
grep "love$" 1.txt
ilove
grep "love\>" 1.txt
ilove
ccc ilove ddd
扩展正则元字符
+ 匹配前导符1到n次
lve
love
loove
looove
##############################
grep -E
egrep
这两个可以识别扩展元字符
#################################
egrep lo+ve 1.txt
love
loove
loove
# *0到多次
? 匹配前导符0到1次
egrep "lo?ve" 1.txt
lve
love
a|b 匹配a或b
egrep "o|v" 1.txt
lve
love
loove
looove
looove
() 组字符
rs
loveable
lovers
##########################################
egrep "love(able|rs)" 1.txt
loveabgle
lovers
egrep "loveable|rs" 1.txt
rs
loveable
lovers