• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

Linux Shell脚本的编程之正则表达式

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

一 正则表达式与通配符

1 正则表达式是用在文件中匹配符合条件的字符串,正则是包含匹配,grep,awk,sed等命令可以支持正则表达式

2 通配符是用来匹配符合条件的文件名,通配符是完全匹配,ls,find,cp这些命令不支持正则表达式,所以只能用Shell自己的通配符来进行匹配了。

二 基础正则表达式

这里引用兄弟连的测试文本

 

1 * 前一个字符匹配0次或任意多次

grep “a*” test_rule.txt

匹配所有内容,包括空白行(由于*可以匹配0次)

grep “aa*” test_rule.txt

匹配至少包含有一个a的行

grep “aaa*” test_rule.txt

匹配至少包含有两个a的行

2 . 匹配除了换行符之外的任意一个字符

grep “s..d” test_rule.txt

匹配s和d直接一定要有两个字符的行

grep “s.*d” test_rule.txt

匹配s和d直接任意字符

grep “.*” test_rule.txt

匹配所有内容

3 ^匹配行首 $匹配行尾

grep “^M” test_rule.txt

匹配以大写M开头的行

grep “n$” test_rule.txt

匹配以小写n结尾的行

grep -n “^$” test_rule.txt

匹配空白行

4 [] 匹配括号中指定的任意一个字符,只匹配一个字符

grep “s[ao]id” test_rule.txt

匹配s和i字母之间,要么是a,要么是o的行

grep “[0-9]” test_rule.txt

匹配任意一个数字

grep “^[a-z]” test_rule.txt

匹配用小写字母开头的行

5 [^] 匹配除括号中以外的任意一个字符

grep “^[^a-z]” test_rule.txt

匹配不用小写字母开头的行

grep “^[^a-zA-Z]” test_rule.txt

匹配不用字符开头的行

6 “\” 转义符

grep “.$” test_rule.txt

匹配以.结尾的行

7 {n} 表示其前面的字符恰好出现n次

grep “a{3}” test_rule.txt

匹配字母a连续出现3次的行

grep “[0-9]{3}” test_rule.txt

匹配包含连续3个数字的行

8 {n,} 表示其前面的字符出现不小于n次

grep “^[0-9]{3,}” test_rule.txt

匹配至少连续3个数字开头的行

9 {n,m} 表示其前面的字符出现不小于n次,最多m次

grep “sa{1,3}i” test_rule.txt

匹配s和i之间最少1个a,最多3个a

好了,Linux Shell编程-正则表达式就总结到这里,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对极客世界网站的支持!


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
Shell脚本切割tomcat的日志文件发布时间:2022-02-11
下一篇:
深入理解Linux中的grep命令发布时间:2022-02-11
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap