Linux中grep工具的使用

grep(Globel Search Regular Expression and Printing out the line)全面搜索正则表达式并把行打印出来,是一种强大的文本搜索工具,是一个对行进行操作的搜索工作,它能使用正则表达式搜索文本,并把匹配的行打印出来。Unix 的 grep 家族包括 grep 、egrep 、 fgrep 。egrep 表示扩展的 grep ,相比 grep 支持更多的元字符。grep -E  相当于 egrep 。fgrep 是 fast grep ,不支持元字符,但是搜索速度更快。grep 过滤的结果被送到屏幕,不影响原文件内容。

grep的用法:grep    选项     模式    文件

grep不加引号直接过滤字符串 ;grep在进行模式匹配的时候必须加引号,单引号和双引号都可以 ;grep在引用变量的时候必须加双引号

grep的选项

  • -r   : 递归搜索
  • -v   :反向选取
  • -o   : 只显示被模式匹配到的字符串,而不是整个行
  • -i   :  匹配时不区分大小写
  • -A  5 : 显示匹配到的行时,显示后面的 5 行
  • -B  5  : 显示匹配到的行时,前面的 5 行
  • -C  5  : 显示匹配到的行时,前后的 5 行
  • -E : 使用扩展的正则表达式

grep支持基本正则表达式: 基本正则表达式

grep -E 也支持扩展正则表达式:扩展正则表达式

grep 支持的字符

  • [:digit:] :  所有数字,相当于 0-9  或者 \d
  • [:lower:] :所有的小写字母
  • [:upper:]:所有的大写字母
  • [:alpha:] :所有的字母
  • [:alnum:] :相当于[0-9a-zA-Z]
  • [:space:] :空白字符,相当于 \s
  • [:punct:] :所有标点符号

grep -E 或  egrep 支持的字符

  • \s:匹配任何空白字符,包括空格、制表符、换页符等,与[ \f\n\r\t\v ] 等效
  • \S:匹配任何非空白字符,与 [ ^\f\n\r\t\v ] 等效
  • \w:匹配任何字类字符,包括下划线,与 [A-Za-z0-9_] 等效
  • \W:匹配任何非单词字符,与[ ^A-Za-z0-9_] 等效

grep -P 支持的字符

  • \d :数字字符匹配,等效于 [0-9]

举例

1、匹配 eg.text 中以 # 开头,且后面跟了至少一个空白字符,而后又跟了任意非空白字符的行
grep "^#[[:space:]]\{1,\}[^[:space:]]" eg.text    
拆开 grep "^# [[:space:]] \{1,\} [^[:space:]]" eg.text
grep -E "^#\s\{1,\}\S" eg.text
拆开  grep -E "^# \s \{1,\} \S" eg.text
 
2、匹配 eg.text 中以 包含了 :一个数字:  的行
grep ":[[:digit:]]:" eg.text
拆开 grep ": [[:digit:]] :" eg.text
grep -P ":\d:" eg.text
拆开 grep -P ": \d :" eg.text

 

分组的例子

grep "l..e.*l..er" test.txt 
grep "\(l..e\).*\1r" test.txt     

匹配 1-255 的数字

grep -E "\<([1-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\>" num.txt
 
 

匹配Email地址:任意长度数字字母@任意长度数字字母

grep -E "^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$" email.txt
 
 

匹配手机号码,把手机号码是1[3|4|5|8]后面接9位数字的过滤出来

grep -E "\<1[3|4|5|8][0-9]{9}\>" tel.txt
 
 

转载链接:https://blog.csdn.net/qq_36119192/article/details/82974781
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: grep 命令用于在文件搜索指定的字符串。它可以帮助您查找文件的特定内容,以便进行更深入的分析。使用 grep 命令的基本语法如下:grep [options] pattern [files] 例如,要在文件 test.txt 搜索字符串 “Hello”,可以使用以下命令grep Hello test.txt ### 回答2: grepLinux系统常用的文本搜索工具,用于在文件查找特定的字符串或模式。它的常见用法格式为: grep [选项] [模式] [文件名] 选项是可选的,可以根据具体需求来使用。常用的选项有: - -i:忽略大小写,在搜索时不区分大小写。 - -r:递归搜索,对指定目录下的所有文件进行搜索。 - -l:只列出包含匹配模式的文件名,而不显示匹配的具体内容。 - -n:显示匹配行的行号。 - -v:只显示不匹配模式的行。 模式是要搜索的字符串或匹配模式,可以使用简单的字符串作为模式,也可以使用正则表达式。 文件名是要进行搜索的文件或目录名。如果没有指定文件名,则grep默认从标准输入读取数据进行搜索。 下面是几个常见的例子: 1. grep 'hello' file.txt 在file.txt文件搜索包含字符串"hello"的行,并将匹配的行输出。 2. grep -i 'hello' file.txt 在不区分大小写的情况下,搜索file.txt文件包含字符串"hello"的行。 3. grep -r 'hello' dir/ 递归搜索dir目录下的所有文件,查找包含字符串"hello"的行。 4. grep -l 'hello' file1.txt file2.txt 只列出file1.txt和file2.txt包含字符串"hello"的文件名。 5. grep -n 'hello' file.txt 在file.txt文件搜索包含字符串"hello"的行,并显示匹配行的行号。 以上是grep命令的一些常用用法,可以根据具体的需求和场景来调整使用。 ### 回答3: grep命令Linux系统非常常用的文本搜索工具,它能够基于给定的模式搜索指定文件的内容。下面是grep命令使用方法。 基本语法:grep [选项] [模式] [文件] 选项: - -i,忽略大小写 - -v,反向匹配,显示不匹配的内容 - -r,递归搜索子目录的文件 - -l,只显示包含匹配内容的文件名 - -n,显示匹配内容所在行的行号 - -c,显示匹配的行数 - -w,匹配整个单词而不是部分匹配 - -A <num>,显示匹配内容后的 <num> 行 - -B <num>,显示匹配内容前的 <num> 行 - -C <num>,显示匹配内容前后的 <num> 行 模式: 在grep命令,可以使用多种不同的模式,模式可以是一个普通字符串、正则表达式或者文件。 示例: 1. 在文件 file.txt 搜索关键词 "hello",并显示匹配的行: ``` grep "hello" file.txt ``` 2. 在文件夹 /tmp 递归搜索包含关键词 "world" 的文件,并显示匹配的文件名: ``` grep -r -l "world" /tmp ``` 3. 在文件 file.txt 搜索以字母 "a" 开头的单词,并显示匹配的行及行号: ``` grep -i -n "\<a\w*" file.txt ``` 总结:grep命令是一种功能强大的文本搜索工具,可以根据给定的模式在指定文件搜索内容。通过掌握grep命令的基本语法和常用选项,可以快速准确地搜索和过滤文件的内容。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值