Linux命令之grep

Linux命令之grep,第1张

grep命令的由来可以追溯到UNIX诞生的早期,在UNIX系统中,搜索的模式(patterns)被称为正则表达式(regular

expressions),为了要彻底搜索一个文件,有的用户在要搜索的字符串前加上前缀global(全面的),一旦找到相匹配的内容,用户就像将其输出(print)到屏幕上,而将这一系列的 *** 作整合到一起就是global

regular expressions print,而这也就是grep命令的全称。

grep命令能够在一个或多个文件中,搜索某一特定的字符模式(也就是正则表达式),此模式可以是单一的字符、字符串、单词或句子。

正则表达式是描述一组字符串的一个模式,正则表达式的构成模仿了数学表达式,通过使用 *** 作符将较小的表达式组合成一个新的表达式。正则表达式可以是一些纯文本文字,也可以是用来产生模式的一些特殊字符。为了进一步定义一个搜索模式,grep

命令支持如表 1 所示的这几种正则表达式的元字符(也就是通配符)。

grep命令的基本格式如下:

[root@localhost ~]# grep [选项] 模式 文件名

这里的模式,要么是字符(串),要么是正则表达式。

grep命令常用选项及含义:

-c:仅列出文件中包含模式的行数。

-i:忽略模式中的字母大小写。

-l:列出带有匹配行的文件名。

-n:在每一行的最前面列出行号。

-v:列出没有匹配模式的行。

-w:把表达式当做一个完整的单字符来搜寻,忽略那些部分匹配的行。

注意,如果是搜索多个文件,grep命令的搜索结果只显示文件中发现匹配模式的文件名而如果搜索单个文件,grep命令的结果将显示每一个包含匹配模式的行。

grep 搜索同时满足多个关键字和满足任意关键字

1、 grep -E "word1|word2|word3" file.txt

满足任意条件(word1、word2和word3之一)将匹配。

这样也可以

egrep 'word1|word2|word3' 文件名

grep 'word1/|word2|word3' 文件名

错误的:

grep 'word1|word2|word3'

2、 grep word1 file.txt | grep word2 |grep word3

必须同时满足三个条件(word1、word2和word3)才匹配。

为什么需要加-E

在使用linux时,经常需要进行文件查找。其中查找的命令主要有find和grep。

两个命令是有区的。

(1)find命令是根据文件的属性进行查找,如文件名,文件大小,所有者,所属组,是否为空,访问时间,修改时间等。

(2)grep是根据文件的内容进行查找,会对文件的每一行按照给定的模式(patter)进行匹配查找。

一.find命令

基本格式:find path expression

1.按照文件名查找

(1)find / -name httpd.conf

在根目录下查找文件httpd.conf,表示在整个硬盘查找

(2)find /etc -name httpd.conf

在/etc目录下文件httpd.conf

(3)find /etc -name ' srm '

使用通配符*(0或者任意多个)。表示在/etc目录下查找文件名中含有字符串‘srm’的文件

(4)find . -name 'srm*'

表示当前目录下查找文件名开头是字符串‘srm’的文件


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/11836539.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-19
下一篇 2023-05-19

发表评论

登录后才能评论

评论列表(0条)

保存