Centos查找目录下所有文件中是否包含指定字符串的方法

2020-01-30 15:29:18于丽

-H:只显示文件名

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

-n:只显示匹配行及其行号

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

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

(2)举例说明:

grep ^[^210] myfile 匹配myfile中以非2、1、0开头的行

grep "[5-8][6-9][0-3]" myfile 匹配myfile中第一位为5|6|7|8,第二位6|7|8|9,第三位为0|1|2|3的三个字符的行

grep "4{2,4}" myfile 匹配myfile中含有44,444或4444的行

grep "?" myfile匹配myfile中含有任意字符的行

(3)grep命令类名

[[:upper:]] 表示[A-Z]

[[:alnum:]] 表示[0-9a-zA-Z]

[[:lower:]] 表示[a-z]

[[:space:]] 表示空格或者tab键

[[:digit:]] 表示[0-9]

[[:alpha:]] 表示[a-zA-Z]

如:grep "5[[:digit:]][[:digit:]]" myfile 匹配myfile中含有5开头接下去两位都是数字的行。

4.awk介绍

可以从文件或字符串中基于指定规则浏览和抽取信息,是一种自解释的变成语言。

(1)awk命令行方式 awk [-F filed-spearator] 'command' input-files

awk脚本:所有awk命令插入一个文件,并使awk程序可执行,然后用awk命令解释器作为脚本的首行,以便通过键入脚本名称来调用它。awk脚本是由各种操作和模式组成。

模式部分决定动作语句何时触发及触发事件。(BEGIN,END)

动作对数据进行处理,放在{}内指明(print)

(2)分隔符、域和记录

awk执行时,其浏览域标记为$1,$2,...$n.这种方法成为域标识。$0为所有域。

(3)举例说明:

awk '{print $0}' test.txt |tee test.out 输出test.txt中所有行$0表示所有域

awk -F : '{print $1} test.txt |tee test.out' 同上。。只是分隔符为":"

awk 'BEGIN {print "IPDaten"}{print $1 "t" $4} END{print "end-of-report"}' test.txt

开始时打印“IPDate”结束时打印“end-of-report”中间打印主体信息,比如总共匹配三条信息,则输出如下:

IPDate

1 first

2 second

3 third

end-of-report

(4)匹配操作符 ~ 匹配,!~ 不匹配

cat test.txt |awk '$0~/210.34.0.13/' 匹配test.txt中为210.34.0.13的行

awk '$0!~/210.34.0.13' test.txt 匹配test.txt中不是210.34.0.13的行

awk '{if($1=="210.34.0.13") print $0}' test.txt 匹配 test.txt中第一个域为210.34.0.13的行。

5.sed介绍

sed不与初始化文件打交道,它操作的只是一个拷贝,然后所有的改动如果没有重定向到一个文件,将输出到屏幕。

sed是一种很重要的文本过滤工具,使用一行命令或者使用管道与grep与awk相结合。是一种非交互性文本流编辑。

(1)调用sed的三种方式

使用sed命令行格式为:sed [options] sed命令 输入文件