shell 运维实战 正则表达式

一 前言

一 名词解释:
正则表达式(regular expression, RE)是一种字符模式,用于在查找过程中匹配指定的字符。
在大多数程序里,正则表达式都被置于两个正斜杠之间;例如/l[oO]ve/就是由正斜杠界定的正则表达式,
它将匹配被查找的行中任何位置出现的相同模式。在正则表达式中,元字符是最重要的概念。

二 工具:
被vim、sed、awk、grep调用

三 场景:
mysql、oracle、php、python ,Apache,Nginx… 需要正则

四 提示:
//?在shell中表示一个字符,shell不区分大小写

五 实战:
示例1
1.需求:
匹配数字的脚本:用户输入创建账号的数量

2.语法:
[[ 1+$ ]]
正确:123 456
错误:5y7
提示:+ 加号是一次到多次

3.示范:
read -p "输入数字才退出: " num

while :
do

if [[ ! n u m =   [ 0 − 9 ] + num =~ ^[0-9]+ num= [09]+ ]];then
echo “error enter!”
read -p “输入数字才退出:” num
else
echo “thank you”
exit 1
fi
done

示例2
1.需求:
匹配字母和数字还有下划线的密码

2.语法:
[a-z0-9_]{7}
正确:111 222 a; sdf 234 a; 21e s21 a;
错误: sdfasda ;1232131 ;234asd
_包含下划线
{7}前方出现7次

3.示范:
read -p "输入七位数字和字母才退出: " num

while :
do

if [[ ! $num =~ [a-z0-9_]{7} ]];then
echo “error enter!”
read -p “输入七位数字和字母才退出:” num
else
echo “thank you”
exit 1
fi
done

示例3
1 需求:
请查找出文本中的IP地址

2 语法:
#egrep ‘[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}.[0-9]{1,3}’ /etc/sysconfig/network-scripts/ifcfg-ens33

#egrep ‘[[:digit:]]{1,3}.[[:digit:]]{1,3}.[[:digit:]]{1,3}.[[:digit:]]{1,3}’ /etc/sysconfig/network-scripts/ifcfg-eth0
IPADDR=172.16.100.1
NETMASK=255.255.255.0
GATEWAY=172.16.100.254

3 示范:在这里插入图片描述
示例4
1 需求:
判断用户输入的字符,小写字符显示lower,大写字符显示upper
数字显示digit,其他则显示特殊字符speical char

2.语法:
[[:lower:]]* 表示小写
[[:upper:]]* 表示大写
[[:digit:]]* 表示数字

3.示范:
#!/bin/bash

read -p "Input char: " char

case $char in
[[:lower:]])
echo “lower…”
;;
[[:upper:]]
)
echo “Upper…”
;;
[[:digit:]]*)
echo “digit…”
;;
*)
echo “Special char…”
;;
esac

示例5
1.需求:
将文本中的tom替换成David
素材:
tom
anatomy
tomatoes
tomorrow
aaatom
Tom

2.不用正则:
:% s/tom/David/g //如tom、anatomy、tomatoes及tomorrow中的“tom”被替换了,而Tom确没被替换

3.使用正则:
:% s/<[Tt]om>/David/g //tom Tom开头或结尾被替换了,anatomy、tomatoes及tomorrow没有被替换

二元字符

一 定义:
元字符是这样一类字符,它们表达的是不同于字面本身的含义

二 分类:
1.基本正则表达式元字符:
^
行首定位符
[root@localhost ~]# grep “root” /etc/passwd
root❌0:0:root:/root:/bin/bash
operator❌11:0:operator:/root:/sbin/nologin

[root@localhost ~]# grep “^root” /etc/passwd
为什么什么少一行?
root❌0:0:root:/root:/bin/bash
$
行尾定位符
love$
.
匹配任意单个字符
[root@localhost ~]# grep abc 1.txt
abc
[root@localhost ~]# grep adc 1.txt
adc
[root@localhost ~]# grep a.c 1.txt
abc
adc

  • 匹配前导符0到多次
    [root@localhost ~]# cat 1.txt
    a
    ab
    abc
    abcd
    abcde
    abcdef
    ggg
    hhh
    iii
    [root@localhost ~]# grep “abc*” 1.txt
    ab
    abc
    abcd
    abcde
    abcdef
    [root@localhost ~]# grep “abcd*” 1.txt
    abc
    abcd
    abcde
    abcdef

.*
任意多个字符
[root@localhost ~]# grep "." 1.txt
a
ab
abc
abcd
abcde
abcdef
ggg
hhh
iii
为什么
.不好使?
[ ]
匹配指定范围内的一个字符
[lL]ove
[ - ]
匹配指定范围内的一个字符,连续的范围
[a-z0-9]ove //[a-Z]=[a-zA-Z]
[^]
匹配不在指定组内的字符
[^a-z0-9]ove //取反
[root@localhost~]# cat 1.txt
love
1ove
|ove

[root@localhost~]# grep [0-9a-Z]ove 1.txt
love
1ove
[root@localhost ~]# grep [^0-9a-Z]ove 1.txt
|ove


用来转义元字符 (’’ “” ),脱意符

[root@localhost ~]# grep “l.” 1.txt
love
l.ve
[root@localhost ~]# grep “l.” 1.txt
l.ve
<
词首定位符
[root@localhost ~]# grep “love” 1.txt
love
iloveyou
[root@localhost ~]# grep “<love” 1.txt
love
>
词尾定位符
love>
()
(…)
匹配稍后使用的字符的标签
:% s/172.16.130.1/172.16.130.5/
:% s/(172.16.130.)1/\15/
:% s/(172.)(16.)(130.)1/\1\2\35/
:3,9 s/(.*)/#\1/ 加注释
x{m}
字符x重复出现m次
[root@localhost ~]# grep o 1.txt
love
loove
looove
[root@localhost ~]# grep “o{3}” 1.txt
looove
x{m,}
字符x重复出现m次以上
o{5,}
x{m,n}
字符x重复出现m到n次
o{5,10}
[root@localhost ~]# egrep “o{4,5}” 1.txt
oooo
ooooo
ioooo
ooooi
iooooi
[root@localhost ~]# egrep “o{5,5}” 1.txt
ooooo

2.扩展正则表达式元字符:
+
匹配1~n个前导字符
[root@localhost ~]# cat 1.txt
lve
love
loove
[root@localhost ~]# egrep lo+ve 1.txt
love
loove

?
匹配0~1个前导字符
lo?ve :?前面的o 有还是没有,都行!
[root@localhost ~]# egrep lo?ve tom.sh
love
lve

a|b
匹配a或b
[root@localhost ~]# egrep “o|v” 1.txt
lve
1ove
loove
looove
loeve
love
Love
iloveyou
l.ve
o
oo
ooo
oooo
ooooo
ioooo
ooooi
iooooi

()
组字符
[root@localhost ~]# egrep “loveable|rs” 1.txt
rs
loveable
lovers
[root@localhost ~]# egrep “love(able|rs)” 1.txt
loveable
lovers

示例1
grep love 1.txt
找love
/^love/
以love开头
/love$/
以love结尾
/l.ve/
l开始,一个任意字符,ve结尾
/lo*ve/
l开始,零个或多个o,ve结尾
/[Ll]ove/
大L 或者小L 开头的 ove
/love[a-z]/
love最后一个小写字母
/love[^a-zA-Z0-9]/
love最后一个(不是字母或者数字),而是符号
[root@localhost ~]# egrep “love[^a-zA-Z0-9]” 1.txt
love,
love?

示例2
/./
所有行
[root@localhost ~]# egrep ".
" 1.txt | wc
/^ / 空 行 / [ A − Z ] . . / 空行 /^[A-Z].. //[AZ]../
开头一个大写,最后2个任意字符
/2[a-z ]3[0-5]/
一个大写开头,0到多个小写或空格,3,最后是0-5的一个数字
/[a-z]
./
0到多个小写字母,最后一个点
/^ *[A-Z][a-z][a-z] / 0 到 多 个 空 格 开 头 , 一 个 大 写 , 一 个 小 写 , 再 一 个 小 写 结 尾 / [ A − Z a − z ] ∗ [ , ] [ A − Z a − z ] ∗ / 0到多个空格开头,一个大写,一个小写,再一个小写结尾 /^[A-Za-z]*[^,][A-Za-z]* /0/[AZaz][,][AZaz]/
0到多个字母开头,非逗号,0到多个英文结尾
/<fourth>/
找个单词
/<f.th>/
找单词
/5{2}2{3}./
5两次2三次和一个点
/3
KaTeX parse error: Expected group after '^' at position 20: …到多个 ,空格或tab的行 /^̲#/ 井号开头的行 /^[ … s/([Oo]ccur)ence/\1rence/
多个r
:1,$ s/(square) and (fair)/\2 and \1/
换个位置


  1. 0-9 ↩︎

  2. A-Z ↩︎

  3. \t ↩︎

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值