正则表达式:Regular regexp)
regexp:
@H_404_13@basic regexp:基本正则表达式 @H_404_13@extended regexp:扩展正则表达式通过使用正则表达式,可以:
1、测试字符串内的模式;
2、可以使用正则表达式来识别文档中的特定文本,完全删除该文本或者用其他文本替换它
3、基于模式匹配从字符串中提取字符串或删除被模式匹配到的字符串
基本正则表达式 (basic regexp):
元字符:
字符匹配:
@H_404_13@.:匹配任意单个字符 @H_404_13@[]:指定范围内的任意单个字符 @H_404_13@[^]:指定范围外的任意单个字符匹配次数(贪婪模式)
@H_404_13@*:匹配其前面的字符任意次.*:任意长度的任意字符
?:匹配其前的字符0次或1次
@H_404_13@\{m,n\}:指定其前面的字符至少出现m次,至多出现n次 @H_404_13@\{m,\}:指定其前面的字符至少出现m次,最多不限位置锚定符:
@H_404_13@^:锚定行首, @H_404_13@$:锚定行尾^$:锚定空白行
@H_404_13@\<:锚定词首 例如:grep "\<r..t" /etc/passwd @H_404_13@\>:锚定词尾 例如:grep "r..t\>" /etc/passwd @H_404_13@\(\):分组引用: \1: 第一个左括号以及与之对应的右括号包含的所有内容
\2: 第二个左括号以及与之对应的右括号包含的所有内容
扩展正则表达式 (extended regexp):
字符匹配:
次数匹配:
*:匹配其前面的字符任意次
?:匹配其前的字符0次或1次
+:匹配其前面的字符至少1次
{m,n}:
位置锚定符:
@H_404_13@^:锚定行首, @H_404_13@$:锚定行尾^$:锚定空白行
@H_404_13@\<:锚定词首 例如:grep "\<r..t" /etc/passwd @H_404_13@\>:锚定词尾 例如:grep "r..t\>" /etc/passwd @H_404_13@():分组 @H_404_13@引用:\1,\2 ....\1: 第一个左括号以及与之对应的右括号包含的所有内容
\2: 第二个左括号以及与之对应的右括号包含的所有内容
C|cat :C或cat (C|c)at:Cat或cat
grep选项:
@H_404_13@-i:忽略大小写 @H_404_13@--color:加上颜色 @H_404_13@-v:反向查找 即显示没有被模式匹配到的行 @H_404_13@-o:只显示被模式匹配到的字符串 @H_404_13@-E:使用扩展正则表达式@H_404_13@-A:表示当某行被grep所指定的模式匹配到以后,不但显示这一行,还显示这一行的后几行。通常后面跟数值 @H_404_13@-B:表示当某行被grep所指定的模式匹配到以后,不但显示这一行,还显示这一行的前几行。通常后面跟数值 @H_404_13@-C:表示当某行被grep所指定的模式匹配到以后,不但显示这一行,还显示这一行的前后几行。通常后面跟数值
示例: