Linux中grep命令详解(linux命令grep -e)难以置信

随心笔谈11个月前发布 admin
102 0



目录一、grep基本介绍二、正则表达式grep实践2.1、输出以 I 开头的行(不区分大小写)2.2、输出以.结尾的行2.3、$符号 注意在Linux平台下, 所有文件的结尾都有一个$符可以利用cat -A 查看文件2.4、^$(代表空行的意思)组合符2.5、.点符号2.6、*符号2.7、.*组合符2.8、^.*t符 (含义: 以任意内容开头, 直到t结束)2.9、[abc]中括号2.10、grep的参数-o2.11、[^abc]中括号中去反三、扩展正则表达式grep实践3.1、+号3.2、?符3.3、|符3.4、()小括号3.5、{n,m}匹配次数

全拼:Global search REgular expression and Print out the line.

作用:文本搜索工具,根据用户指定的“模式(过滤条件)”对目标文本逐行进行匹配检查,打印匹配到的行.

模式:由正则表达式的元字符及文本字符所编写出的过滤条件﹔

grep命令是Linux系统中最重要的命令之一,功能是从文本文件或管道数据流中筛选匹配的行和数据,如果再配合正则表达式,功能十分强大,是Linux运维人员必备的命令

grep命令里的匹配模式就是你想要找的东西,可以是普通的文字符号,也可以是正则表达式

首先先看一下这个测试文件的内容吧

注: 这里的-i代表不区分大小写, -n代表显示匹配行和行号

注: 因为.在这里有着特殊含义, 所以要用\转义一下, 如果不加转义字符的话, grep就会把它当做正则表达式来处理(.代表的含义是匹配任意一个字符)

找出文件的空行, 以及行号

“.”点表示任意一个字符, 有且只有一个, 不包含空行

“*”表示找出前一个字符0次或一次以上

找出文件中i出现0次或多次的行和行号

“.*”表示所有内容, 包括空行

中括号表达式,[abc]表示匹配中括号中任意一个字符, a或b或c,常见的形式如下;

[a-z]匹配所有小写单个字母[A-Z]匹配所有单个大写字母[a-zA-Z]匹配所有的单个大小写字母[0-9]匹配所有单个数字[a-zA-ZO-9]匹配所有数字和字母

匹配abc字符中的任意一个,得到它的行数和行号 

使用”-o”选项, 可以值显示被匹配到的关键字, 而不是讲整行的内容都输出.

显示出文章中有多少行有a

“-c”只统计匹配的行数

[^abc]或[^a-c]这样的命令, “^”符号在中括号中第一位表示排除, 就是排除字符a,b,c

注: 出现再中括号里的尖角号表示取反

此处使用grep -E进行实践扩展正则, egrep官网已经弃用了

+号表示匹配前一个字符1一次或多次,必须使用grep-E扩展正则

匹配前一个字符0次或1次

找出文件中包含gd或者god的行

竖线|再正则中是或者的意思

找出opt目录中txt结尾的文件, 其名字中包含a或者e, 不区分大小写(-i)

将一个或多个字符捆绑在一起, 当作一个整体进行处理

{n,m}:匹配前一个字符至少n次, 最多m次

{n,}: 匹配前一个字符至少n次, 没有上限

{,m}: 匹配前一个字符最多m次,可以没有

重复前一个字符各种次数, 可以通过-o参数显示明确的匹配过程

到此这篇关于Linux中grep详解的文章就介绍到这了,更多相关Linux中grep详解内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:linux?shell中Grep命令查找多个字符串(grep同时匹配多个关键字或任意关键字)Linux常用命令之grep命令用法详解Linux中grep和egrep命令详解linux中使用grep命令详解linux 中grep 匹配制表符 和 换行符的命令Linux 使用grep筛选多个条件及grep常用过滤命令Linux中利用grep命令如何检索文件内容详解

© 版权声明

相关文章