Linux文本处理之grep文本过滤命令

深入理解Linux grep命令:文本过滤与正则表达式
本文介绍了Linux中的grep命令,详细讲解了grep的基本格式,包括匹配条件、处理文件的方式,字符匹配次数和位置的设定,以及正则表达式的使用,特别是扩展正则表达式在grep中的应用。

一、什么是grep?

grep (缩写来自Globally search a Regular Expression and Print)是一种强大的文本搜索工具
它能使用特定模式匹配(包括正则表达式)搜索文本,并默认输出匹配行
Unix的grep家族包括grep、egrep和fgrep,Windows系统下类似命令FINDSTR

grep的工作方式是这样的,它在一个或多个文件中搜索字符串模板
如果模板包括空格,则必须被引用,模板后的所有字符串被看作文件名,搜索的结果被送到屏幕,不影响原文件内容
grep可用于shell脚本,因为grep通过返回一个状态值来说明搜索的状态
如果模板搜索成功,则返回0,如果搜索不成功,则返回1,如果搜索的文件不存在,则返回2
我们利用这些返回值就可进行一些自动化的文本处理工作

二、 grep 的格式(贪婪模式的匹配)

2.1 grep 匹配条件 处理文件

grep   root   passwd搜索全文中的root
grep  ^root  passwd搜索全文中以root开头的
grep  root$  passwd搜索全文中以root结尾的
grep -i root   passwd忽略大小写
grep -E "root|ROOT" passwd同时匹配多个条件

在这里插入图片描述

2.2 grep 中字符的匹配次数设定

*字符出现 [0- 任意次 ]
\?字符出现 [0-1 次 ]
\+字符出现 [1- 任意次 ]
\{n\}字符出现 [n 次 ]
|{m,n\} 字符出现 [ 最少出现 m 次,最多出现 n 次 ]
\{0,n\}字符出现 [0-n 次 ]
\{m,\}字符出现 [ 至少 m 次 ]
\(xy\)\{n\}xy 关键字出现 [n 次 ]
.*关键字之间匹配任意字符

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

2.3 grep 中字符的匹配位置设定

^ 关键字  寻找以什么开头的关键字
关键字 $ 寻找以什么结尾的关键字
\< 关键字
关键字 \>
\< 关键字 \>

在这里插入图片描述

2.4 grep 正则表达式与扩展正则表达式

正规的 grep 不支持扩展的正则表达式子 , 竖线是用于表示”或”的扩展正则表达式元字符 , 正规的 grep 无法识别
加上反斜杠 , 这个字符就被翻译成扩展正则表达式 , 就像 egrp,和grep -E 一样

ps:

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值