环视结构不匹配任何字符,只匹配文本中的特定位置,一种类型的环视叫顺序环视(lookahead),作为表达式的一部分,顺序环视顺序(从左至右)查看文本,尝试匹配子表达式,如果能够匹配,就返回匹配成功信息。肯定型顺序环视用特殊的序列(?=...)表示,例如(?=d)表示
如果当前位置右边的字符是数字则匹配成功,另一种环视称为逆序环视,它逆序(从右向左)查看文本,它用特殊的序列(?<=...)表示,
例如(?<=d) 如果当前位置的左边有一位数字则匹配成功(也就是说紧跟在数字后面)
环视:不匹配任何字符,只匹配一个位置
(?=...) 肯定顺序环视 子表达式能够匹配右侧文本
(?<=...) 肯定逆序环视 子表达式能够匹配左侧文本
(?!...) 否定顺序环视 子表达式不能匹配右侧文本
(?<!...) 否定逆序环视 子表达式不能匹配左侧文本
s/Jeff/Jeff's/g
s/(Jeff)(s)/$1'$2/g
s/(?<=Jeff)(?=s)/'/ 这个表达式实际上没有匹配任何字符,只是匹配了我们希望插入撇号的位置,在这种情况下,我们并没有“替换任何字符”,而是插入了一个撇号
非捕获型括号 (?:...) 可以提高性能
grep 不支持多选结构'^if|num$' egrep支持
d 数字 等价于[0-9],如果工具软件支持Unicode,能匹配所有的Unicode数字
D 非数字字符 等价于[^d]
w 单词中的字符 一般等价于[a-zA-Z0-9_] 某些工具软件中w不能匹配下划线
W 非单词字符 等价于 [^w]
s 空白字符 在支持ASCII的系统中,它通常等价于[ f v]
S 非空白字符 等价于 [^s]
[^u] 表示 “匹配一个未列出的字符”,而不是“不要匹配列出的字符”
* ? + 只作用于之前紧邻的元素
未完待续。。。