文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Linux中grep命令怎么用

2023-06-09 16:51

关注

小编给大家分享一下Linux中grep命令怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

介绍

Linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹 配的行打印出来。grep全称是Global Regular Expression Print,表示全局正则表达式版本,它的使用权限是所有用户。

grep [-acinv] [--color=auto] '查找字符串' filename

参数:

    -a :将binary文件以text文件的方式查找数据

    -c :计算找到‘查找字符串'的次数

    -i :忽略大小写的区别,即把大小写视为相同

    -n :顺便输出行号

    -v :反向选择,即显示出没有‘查找字符串'内容的那一行

    -l :只显示匹配的文件,不显示具体内容

    -f<规则文件> : 指定规则文件,其内容含有一个或多个规则样式,让grep查找符合规则条件的文件内容,格式为每行一个规则样式。  

实例:

#取出文件/etc/man.config中包含MANPATH关键词的行,并把找到的关键字加上颜色grep --color=auto MANPATH /etc/man.config#把ls -l的输出中包含字母file(不区分大小写)的内容输出ls -l | grep -i file#在文件 '/var/log/messages'中查找关键词"Aug" grep Aug /var/log/messages #在文件 '/var/log/messages'中查找以"Aug"开始的行grep ^Aug /var/log/messages #选择 '/var/log/messages' 文件中所有包含数字的行 grep [0-9] /var/log/messages #在目录 '/var/log' 及随后的目录中搜索字符串"Aug" (递归查找)grep Aug -R /var/log/* #在当前目录搜索带'energywise'行的文件grep 'energywise' *      #在当前目录及其子目录下搜索'energywise'行的文件grep -r 'energywise' *  #查找指定进程ps -ef|grep svn#从文件中读取关键词进行搜索,输出test.txt文件中含有从test2.txt文件中读取出的关键词的内容行cat test.txt | grep -f test2.txt

grep与正规表达式:

字符类的搜索:如果我想要搜寻 test 或 taste 这两个单字时,可以发现到,其实她们有共通的 ‘t?st' 存在~这个时候,我可以这样来搜寻:

grep -n 't[ae]st' regular_express.txt

其实 [] 里面不论有几个字节,他都谨代表某『一个』字节, 所以,上面的例子说明了,我需要的字串是『tast』或『test』两个字串而已!

字符类的反向选择 [^] :如果想要搜索到有 oo 的行,但不想要 oo 前面有 g,如下

grep -n '[^g]oo' regular_express.txt

字符类的连续:再来,假设我 oo 前面不想要有小写字节,

grep -n '[^a-z]oo' regular_express.txt

当我们在一组集合字节中,如果该字节组是连续的,例如大写英文/小写英文/数字等等, 就可以使用[a-z],[A-Z],[0-9]等方式来书写,那么如果我们的要求字串是数字与英文呢? 呵呵!就将他全部写在一起,变成:[a-zA-Z0-9]。

我们要取得有数字的那一行,就这样:

grep -n '[0-9]' regular_express.txt

行首与行尾字节 ^ $

行首字符:如果我想要让 the 只在行首列出呢? 这个时候就得要使用定位字节了!我们可以这样做:

grep -n '^the' regular_express.txt

开头是小写字节的那一行就列出呢?可以这样:

grep -n '^[a-z]' regular_express.txt

我不想要开头是英文字母,则可以是这样:

grep -n '^[^a-zA-Z]' regular_express.txt

^ 符号,在字符类符号(括号[])之内与之外是不同的! 在 [] 内代表『反向选择』,在 [] 之外则代表定位在行首的意义!

行尾结束为小数点 (.) 的那一行:

grep -n '\.$' regular_express.txt

特别注意到,因为小数点具有其他意义(底下会介绍),所以必须要使用转义字符()来加以解除其特殊意义!

#找出空白行grep -n '^$' regular_express.txt

任意一个字节 . 与重复字节 *

    . (小数点):代表『一定有一个任意字节』的意思;

    * (星号):代表『重复前一个字符, 0 到无穷多次』的意思,为组合形态

#需要找出 g??d 的字串,亦即共有四个字节, 起头是 g 而结束是 d ,我可以这样做:grep -n 'g..d' regular_express.txt#查找至少两个 o 以上的字串,『o*』代表的是:『拥有空字节或一个 o 以上的字节』grep -n 'ooo*' regular_express.txt#想要字串开头与结尾都是 g,但是两个 g 之间仅能存在至少一个 o ,亦即是 gog, goog, gooog.... 等等grep -n 'goo*g' regular_express.txt#找出 g 开头与 g 结尾的行,当中的字符可有可无grep -n 'g.*g' regular_express.txt#找到两个 o 的字串,可以是:grep -n 'o\{2\}' regular_express.txt#找出 g 后面接 2 到 5 个 o ,然后再接一个 g 的字串,他会是这样:grep -n 'go\{2,5\}g' regular_express.txt#2 个 o 以上的 goooo....g 呢?除了可以是 goo*g ,也可以grep -n 'go\{2,\}g' regular_express.txt#从多个文件中查找关键词grep 'linux' test.txt test2.txt

以上是“Linux中grep命令怎么用”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网行业资讯频道!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     801人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     348人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     311人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     432人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-人工智能
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯