新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章主要介绍了Linux中Shell脚本编程之正则表达式的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
成都创新互联长期为1000多家客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为青山湖企业提供专业的网站设计制作、网站建设,青山湖网站改版等技术服务。拥有十载丰富建站经验和众多成功案例,为您定制开发。一 正则表达式与通配符
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脚本编程之正则表达式的示例分析”这篇文章对大家有帮助,同时也希望大家多多支持创新互联网站建设公司,,关注创新互联行业资讯频道,更多相关知识等着你来学习!