grep命令的使用

本文详细介绍了Linux系统中常用的文本处理工具grep、sed和awk的使用方法。grep用于过滤文本行,支持扩展正则表达式、上下文显示等功能;sed则是一个文本行编辑器,能对文本进行替换、删除等操作;awk则是一个强大的报告生成器,擅长数据格式化输出。通过这些工具,可以高效地处理和分析大量文本数据。
摘要由CSDN通过智能技术生成

参考文章

  • grep:文本行过滤工具 sed:
  • 文本行编辑器(流编辑器)
  • awk: 报告生成器,输出格式化
grep的用法结构:
grep [option] PATTERN [filename]
[option]常用可选参数
-v:invert,反转查找,输出与模式不相符的行;(==反选==)
-An:after-context,同时显示符合条件行的下面n行;(==显示该行及之后==)
-Bn:before-context,同时显示符合条件行的上面n行;(==显示该行及之前==)
-Cn:同时显示符合条件行的上面n行和下面n行;
-E:extended regular,支持扩展正则表达式;
-o:only-matching,仅显示匹配的字符串;
-f:根据文件内容进行匹配;
-d:--directories=<进行动作>   当指定要查找的是==目录==而非文件时,必须使用这项参数,否则grep指令将回报信息并停止动作。
-a:以文本文件方式搜索,不忽略二进制的数据;
-c:计算找到的符合行的次数;
-i:ignore-case忽略大小写;
-n:line-number,在显示符合范本样式的那一行之前,标示出该行的行数编号;
-P  "\t"  --》得到Tab键 --》使用perl语言的正则语法,支持\t表示table键,\s表示空白。
-r:--recursive   此参数的效果和指定“-d recurse”参数相同。(==递归遍历目录查找==
pattern–正则表达式:

模式其实就是一个公式,里面有字母+数字+特殊符号,组合成一个正则表达式,表达出某个含义。
1.字符匹配:

    . 任意一个字符 
    [] 范围内的任意一个字符
    [^]范围外的任意一个字符
    字符类:[:digit:]  [:alnum:]  [:alpha:]  [:lower:] [:upper:] [:space:] [:punct:]  

2.次数匹配

 	* 匹配前面的字符0次到n次  
    \?匹配前面的字符0次到1次
    + 匹配前面的字符1次到n次
    \{m\}匹配前面的字符m次
    \{m,n\}匹配前面的字符m到n次
    \{0,n\}匹配前面的字符0到n次
    \{m,\}  匹配前面的字符至少m次

3.位置锚定

 	^  锚定行首
    $  锚定行尾
    \b 锚定词首和锚定词尾
    \>  锚定词尾
    <\ 锚定词首
grep 搜索含子目录的目录

默认情况下,’grep’只搜索当前目录。如果 此目录下有许多子目录,’grep’会以如下形式列出:
grep: sound: Is a directory
这可能会使’grep’ 的输出难于阅读。这里有两种解决的办法:

明确要求搜索子目录:grep -r
或忽略子目录:grep -d skip

🐖 如果有很多输出时,可以通过管道将其转到’less’上阅读:

$ grep magic /usr/src/Linux/Documentation/* | less
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值