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

文章目录

    • 一、什么是grep?
    • 二、 grep 的格式(贪婪模式的匹配)
      • 2.1 grep 匹配条件 处理文件
      • 2.2 grep 中字符的匹配次数设定
      • 2.3 grep 中字符的匹配位置设定
      • 2.4 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同时匹配多个条件

Linux文本处理之grep文本过滤命令_第1张图片

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

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

Linux文本处理之grep文本过滤命令_第2张图片
Linux文本处理之grep文本过滤命令_第3张图片
Linux文本处理之grep文本过滤命令_第4张图片

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

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

Linux文本处理之grep文本过滤命令_第5张图片

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

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

ps:

Linux文本处理之grep文本过滤命令_第6张图片

你可能感兴趣的:(shell)