Linux中grep命令基本用法

grep命令基本用法:

1.grep程序按照如下方式接受选项和参数。
grep [options] regex [file...]	#其中字符串regex代表的是某个正则表达式。
2.grep选项功能描述

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-nzNTyBL8-1619061339167)(C:\Users\Autumn。\AppData\Roaming\Typora\typora-user-images\image-20210422101133935.png)]

3.文字字符和元字符
(1)文字字符:

​ 除了元字符其他所有字符被当作文字字符。(反斜杠字符可用来创建元序列)

(2)元字符:用于指定更加复杂的匹配的元字符
^ $ . [ ] { } - ? * + ( ) | \
4.元字符匹配规则
(1)任意字符: .

​ 元字符是“点"字符或者句点字符,该字符用于匹配.任意字符。如果将其加进某个正则表达式中,它将会在对应位置匹配任意字符。

grep -n *San datebook.txt       #匹配datebook.txt文件中包含所有以San结尾的字符所在行
(2)锚: ^ $

​ 插入符(^)和美元符号( ) 在 正 则 表 达 式 被 当 做 锚 , 也 就 是 说 正 则 表 达 式 只 与 行 的 开 头 ( ) 或 是 末 尾 ( ) 在正则表达式被当做锚,也就是说正则表达式只与行的开头(^)或是末尾( )()()的内容进行匹配比较。

grep -n '^San' datebook.txt		#匹配以San开头的所在行
grep -n '^San' datebook.txt		#匹配以San结尾的所在行
grep -n '^$' datebook.txt		#匹配空行
grep -n '^K.r.n$' datebook.txt	#匹配第一个字母是K,第三个r第五个是n的字符

在这里插入图片描述

(3)中括号表达式:[ ]

​ 中括号除了可以用于匹配正则表达式中给定位置的任意字符外,还可以用于匹配指定字符集中的单个字符。借助于中括号,我们可以指定要匹配的字符集(也包括那些可能会被解释为元字符的字符)。如下命令行则利用了一个两个字母组成的字符集,用于匹配包含San或san字符串的文本行。

grep '[Ss]an' datebook.txt		#匹配包含San或san字符

一个字符集可以包含任意数目的字符,并且当元字符放置到中括号中时, .会失去它们的特殊含义,然而,在两种情况下,则会在中括号中使用元字符,并且会有不同的含义。

​ 第一个就是插入符(^), 它在中括号内使用表示否定;

​ 另外一个是连字符(-), 它表示字符范围。

(4)否定:^

​ 如果中括号内的第一-个字符是插入符 (^), 那么剩下的字符则被当作不应该在指定位置出现的字符集。

grep '[^Ss]an' datebook.txt		#匹配包含San或san字符

注意:插入符号 “^” 只有是中括号表达式中的第一 个字符时才会被当作否定符,如果不是第一个 “^” ,将会丧失其特殊含义而成为普通字符。

(5)或选项: |

​ 或选项则用于从字符串集或正则表达式集中寻找匹配项。

root@Autumn:/$ echo "San" | grep -E 'San|san'		#echo的输出与San匹配,成功则输出
San
root@Autumn:/$ echo "san" | grep -E 'San|san'
san

​ 由于此处使用的是扩展特性,所以grep增加了-E选项(虽然可以使用egrep 命令来代替),并且**将正则表达式用引号引起来以防止shell将元字符“|"当作管道操作符来处理。**另外,或选项并不局限于两种选择,还可以有更多的选择项。

(6)限定符:? * + {}
?:匹配某元素0次或1次
* :匹配某元素多次或零次
+ :匹配某元素一次或 多次
{ } :以指定次数匹配某元素
  • 2
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答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命令基本语法和常用选项,可以快速准确地搜索和过滤文件的内容。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值