文本查找的需要
grep,egrep,fgrepgrep:Global Research。根据模式,去搜索文本,并将符合模式的文本行显示出来
Pattern:文本字符和正则表达式的元字符组合而成匹配条件grep:
grep [options] PATTERN [FILE...]
[root@localhost ~]# grep 'root' /etc/passwd
root:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/root:/sbin/nologin
[root@localhost ~]#
-i:不考虑大小写
--color:颜色高亮
-v:反向查找,显示没有被模式匹配的行
-o:只显示被模式匹配的字符串
正则表达式:REGular EXPression,简写为REGEXP
元字符:
.:匹配任意单个字符
[]:匹配指定范围内的任意单个字符
[^]:匹配指定范围外的任意单个字符字符个数:
*:匹配其前面的字符任意次
a*b:的意思就是a可以出现任意次(包括0次),随后跟了个b。比如 b、ab、aab、
a.*b:这才表示任意长度的任意字符
.*:任意长度的任意字符
默认情况下,正则表达式工作在贪婪模式下。就是能匹配到哪就匹配到哪,尽可能长的去匹配。比如上面的a.*b:amnb是可以的,amnbmnbmnb也是可以匹配到的
\?:匹配其前面的字符一次或0次
\{m,n\}:匹配前面的字符至少m次,至多n次位置锚定:
^:锚定行首,此字符后面的任意内容必须出现在行首
$:锚定行尾,此字符前面的任意内容必须出现在行尾
^$:空白行\<或者\b:锚定词首,其后面的任意字符必须作为单词的首部出现
\>或者\b:锚定词尾,其前面的任意字符必须作为单词的尾部出现分组:
\(\):分组
后向引用
\1:引用第一个左括号以及与之对应的右括号所包括的所有内容
\2:
\3:
...grep:使用基本正则表达式定义的模式来过滤文本的命令
-i
-v
-o
--color
-E:使用扩展正则表达式
-A #:其后(#是数字,数字几就是其几行)
-B #:其前
-C #:其前后
扩展正则表达式:字符匹配:
.
[]
[^]次数匹配:
*:
?:
+:匹配其前面的字符至少一次,
{m,n}:扩展正则表达式的花括号不需要使用反斜线位置锚定:
^
$
\<
\>分组:
():分组
\1,\2,\3,...或者
|:or的意思,a|b是a或者bC|cat:C或cat。或者是整个两边都或
(C|c):利用分组匹配小c或大Cgrep -E = egrep
fgrep:fast,不支持正则表达式
grep 输出两个匹配行之间内容 grep匹配任意字符
转载本文章为转载内容,我们尊重原作者对文章享有的著作权。如有内容错误或侵权问题,欢迎原作者联系我们进行内容更正或删除文章。
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
【ArkTS】鸿蒙开发 比较两个数的大小 用户界面输入两个数并输出较大数
【HarmonyOS】 鸿蒙开发 (比较两个值大小,输出较大值)在DevEco Studio中开发,用户界面输入两个值,比较两个值大小并输出较大值。主要是练习了对TextInput属性的应用。
鸿蒙开发 TextInput属性 用户界面输入 两个值比较大小 ArkTS -
java 正则表达式匹配数字去掉前面的字符
java 正则表达式匹配数字去掉前面的字符
字符串 System 正则表达式