当前位置:首页 > 电脑常识 > 正文

Linux Shell脚本的编程之正则表达式的详细介绍 8090安适门户

11-20 电脑常识

一 正则表达式与通配符
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开头的行

Linux Shell脚本的编程之正则表达式的详细介绍 8090安详门户


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次的行

温馨提示: 本文由杰米博客推荐,转载请保留链接: https://www.jmwww.net/file/pc/12759.html

博客主人杰米WWW
杰米博客,为大家提供seo以及it方面技巧喜欢的朋友收藏哦!
  • 11365文章总数
  • 1378074访问次数
  • 建站天数
  •