grep

 

扩展grep(grep -E 或者 egrep):
使用扩展grep的主要好处是增加了额外的正则表达式元字符集。

 

打印所有包含NW或EA的行。如果不是使用egrep,而是grep,将不会有结果查出。

    # egrep 'NW|EA' testfile     
    northwest       NW      Charles Main        3.0     .98     3       34
    eastern         EA      TB Savage           4.4     .84     5       20

 

对于标准grep,如果在扩展元字符前面加\,grep会自动启用扩展选项-E。

#grep 'NW\|EA' testfile
northwest       NW      Charles Main        3.0     .98     3       34
eastern         EA      TB Savage           4.4     .84     5       20

 

搜索所有包含一个或多个3的行。

复制代码
# egrep '3+' testfile
# grep -E '3+' testfile
# grep '3\+' testfile        
#这3条命令将会
northwest       NW      Charles Main          3.0     .98     3       34
western         WE      Sharon Gray           5.3     .97     5       23
northeast       NE      AM Main Jr.           5.1     .94     3       13
central         CT      Ann Stephens          5.7     .94     5       13
复制代码

 

搜索所有包含0个或1个小数点字符的行。
    

复制代码
# egrep '2\.?[0-9]' testfile 
# grep -E '2\.?[0-9]' testfile
# grep '2\.\?[0-9]' testfile 
#首先含有2字符,其后紧跟着0个或1个点,后面再是0和9之间的数字。
western         WE       Sharon Gray          5.3     .97     5       23
southwest       SW      Lewis Dalsass         2.7     .8      2       18
eastern         EA       TB Savage             4.4     .84     5       20
复制代码

 

搜索一个或者多个连续的no的行。
    

# egrep '(no)+' testfile
# grep -E '(no)+' testfile
# grep '\(no\)\+' testfile   #3个命令返回相同结果,
northwest       NW      Charles Main        3.0     .98     3       34
northeast       NE       AM Main Jr.        5.1     .94     3       13
north           NO      Margot Weber        4.5     .89     5       9

 

不使用正则表达式

fgrep 查询速度比grep命令快,但是不够灵活:它只能找固定的文本,而不是规则表达式。

如果你想在一个文件或者输出中找到包含星号字符的行

fgrep  '*' /etc/profile
for i in /etc/profile.d/*.sh ; do

或
grep -F '*' /etc/profile
for i in /etc/profile.d/*.sh ; do

 

转载于:https://www.cnblogs.com/gaoxianzhi/p/3214382.html

### grep 命令简介 `grep` 是一个非常强大的文本搜索工具,它能够使用正则表达式来搜索文本,并将匹配的行打印出来。`grep` 支持多种模式匹配,包括基本正则表达式、扩展正则表达式以及固定字符串匹配等[^2]。 #### 基本用法 - **搜索特定模式**:最简单的使用方式是在指定文件中搜索某个模式。例如,要在一个文件中查找包含 "hello" 的所有行,可以使用如下命令: ```bash grep 'hello' filename.txt ``` - **忽略大小写**:如果希望搜索时不区分大小写,可以加上 `-i` 参数: ```bash grep -i 'hello' filename.txt ``` - **显示行号**:通过 `-n` 参数可以让 `grep` 显示匹配行的行号: ```bash grep -n 'hello' filename.txt ``` - **反向匹配**:想要找出不包含特定模式的行,可以利用 `-v` 选项: ```bash grep -v 'hello' filename.txt ``` #### 高级特性 - **使用正则表达式**:`grep` 支持使用正则表达式进行更复杂的模式匹配。比如,要查找以 "start" 开头并以 "end" 结尾的行,可以这样写: ```bash grep '^start.*end$' filename.txt ``` - **POSIX字符类**:为了确保在不同的字符编码环境中一致性,`grep` 支持 POSIX 定义的一些特殊字符类。例如,`[[:alnum:]]` 表示任何字母或数字字符: ```bash grep '[[:space:]]' ``` - **递归搜索**:当需要在整个目录结构中查找时,可以采用 `-r` 或者 `--recursive` 选项: ```bash grep -r 'pattern' /path/to/directory/ ``` - **组合多个模式**:可以通过 `-e` 参数指定多个搜索模式,或者直接在单个命令中用管道符 `|` 分隔不同的模式: ```bash grep -e 'pattern1' -e 'pattern2' filename.txt # 或者 egrep 'pattern1|pattern2' filename.txt ``` 以上仅是 `grep` 功能的一小部分展示。`grep` 还有许多其他选项和用法,可以根据具体需求探索更多高级功能。对于初学者来说,《鸟哥的Linux私房菜》提供了详尽的教程和实例,非常适合学习[^1]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值