Hi, 我是小萝卜算子
近来有小伙伴私信我,说grep配合正则更无敌,但是正则总记不住,能不能整一个简单的参考,有需求必须安排一章
一、介绍
正则表达式是对字符串和特殊字符操作的一种逻辑公式,做开发的或多或少都接触过正则,其在检索匹配和替换领域能发挥超乎寻常的作用,掌握好正则表达式往往能达到事半功倍的效果,详情请看下文
二、常用字符
匹配符 (只列出常用的)
^: 匹配字符串开始,在方括号内标识非,即排除 $: 匹配字符串结束 []: 匹配括号中的任一字符 [a-z] 匹配a-z ; [^A-Z] 不匹配A-Z; . : 匹配除换行符之外所有的数据 \d(D): 匹配(非)数字 \w(W): 匹配(非)数字、字母以及下滑线 \s(S) : 匹配(非)空格、换行符 \r -- \n -- \t: 回车 -- 换行 -- 制表符 \b(B): 匹配单词的(非)边界 |
eg:
匹配以a或者b或者c开头的数据
echo 'abcd' | grep -P '^(a|b|c)'
因为是单字符所以还可改为
echo 'abcd' | grep -P '^[abc]'
限定符
{n}: 次数=n {n,}: 次数>=n {n,m}: m>=次数>=n *: 次数>=0 +: 次数>=1 ?: 0或者1(跟在限定符后表示非贪婪) |
eg:
匹配最少连续三个ab组成的字符
echo 'mmababcdabababnn' | grep -P '(ab){3,}'
可以看出前面连续两个ab组成的字符没被匹配到
echo 'mmababcd