1. 什么是正则表达式:

    正则表达式就是处理字符串的方法,他是以行为单位来进行字符串的处理行为,正则表达式通过一些特殊符号的辅助,可以让用户轻易达到查找,删除,替换某种特定字符串的处理程序,其实就像相当与添加位置限定符,数量限定符,字符想定符来进行范围缩减匹配。


2.grep工具:

   首先grep就是一个查找工具,然后通过正则表达式完成字符串的搜索。

   存在3种限定符:

首先是字符限定符:

wKioL1ds-b7znjbDAAC02XtIx6o155.png

数量限定符:

wKiom1ds-b6AqpxkAADuk6KOFII285.png

wKiom1ds-b-y8zbmAABOzC1hDBE800.png

位置限定符:

wKioL1ds-cDgmsXrAACyIbvf5CM604.png

其他限定符:

wKioL1ds-cHx_dW5AACi_VlN2vI614.png

是grep正则表达式的Extended规范,Basic规范也有这些语法,只是字符?+{}|()应

解释为普通字符,要表示上述特殊含义则需要加\转义。如果用grep而不是egrep,并且不加-E

参数,则应该遵照Basic规范来写正则表达式。 (一定要注意!!!!!)


下面我们主要来说一下grep的各种选项,并结合上以上的各种限定符来使用一下:

常用的grep选项有:
-c 只输出匹配行的计数。
-i 不区分大小写(只适用于单字符)。
-h 查询多文件时不显示文件名。
-l 查询多文件时只输出包含匹配字符的文件名。
-n 显示匹配行及行号。
-s 不显示不存在或无匹配文本的错误信息。
-v 显示不包含匹配文本的所有行。


一个一个来:

首先我们在终端下输入命令:count=0;while [ $count -le 100 ];do echo "hello abc $count">>file;let count++;done 


创建一个100行的file文件:

-c:只输出匹配行的计数。

wKiom1dtAKryC4aGAAA9yAOnhHU585.png

-------------------------------------------------------------------------------------------


-i:不区分大小写(只适用于单字符)。

使用这个之前我们使用sed工具对file文件进行转换:sed工具以后会写博文。

sed -i /he/s/he/HE/g file

表示我们把每一行的he都转换成了HE

然后我们使用grep -i;

wKiom1dtAbvRKcM8AAAoHxYdb5k625.png

-------------------------------------------------------------------------------------------


-h 查询多文件时不显示文件名。

wKioL1dtA9iQJRuqAAB7SkIefD8511.png

-------------------------------------------------------------------------------------------


-n 显示匹配行及行号。

wKiom1dtA9mBmze9AABxt1Ikr98553.png

-------------------------------------------------------------------------------------------


-s 不显示不存在或无匹配文本的错误信息。

wKiom1dtA9nCU_diAAAk4vtyya8530.png

-------------------------------------------------------------------------------------------


-v 显示不包含匹配文本的所有行。

wKioL1dtA9qD89StAACVXvAnKWA158.png

-------------------------------------------------------------------------------------------

-l 查询多文件时只输出包含匹配字符的文件名。

wKioL1dtBEiTgQrpAAAkIbxuXXk979.png


常用的就这些了=。=