正则表达式
正则表达式都被置于两个正斜杠之间;如/l[oO]ve/
示例
匹配数字的脚本,用户输入创建账号的数量
语法: [[ ^[0-9]+$ ]]
表示必须输入数字
#!/bin/bashwhile :
do
read -p "输入数字:" numif [[ $num =~ ^[0-9]+$ ]]thenecho "再见"exitelseecho "重新输入"fi
done
#!/bin/bash
read -p "你好,请输入姓名:" namewhile :
do
read -p "你是傻子吗,请输入 是:" numif [ $num = "是"]thenecho "大傻子,$name,再见"exitelseecho "重新输入"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.txtab
abc
abcd
abcde
abcdef#ab后面好想有c,好像也没有,c出现0次到多次grep "abcde*" 1.txtabcd
abcde
abcdef#e出现0次到多次
.* 任意多个字符
grep ".*" 1.txta
ab
abc
abcd
abcde
abcdef
gg
hh
ii###################################
为什么*.不可以
*前面没有前导符
[ ] 匹配指定范围内的一个字符
vim 1.txt
love
Love
1love
|ove#################################################
grep "[lL]ove" 1.txtlove
Love#取反
grep "[^lL1]ove" 1.txt
|ovegrep "[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.3192.168.2.2:% s/\(192\)/123\1/
#在192前面加123
x\{m\} 字符x重复几次
love
loove
looove
loooove
looooove
loooooovegrep "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
loveyougrep "\<love" 1.txt
loveyou
eee loveyou fffgrep "love$" 1.txt
ilovegrep "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
loversegrep "loveable|rs" 1.txt
rs
loveable
lovers