首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >正则表达式与预期数据不匹配

正则表达式与预期数据不匹配
EN

Unix & Linux用户
提问于 2022-09-19 06:40:40
回答 1查看 91关注 0票数 3

我试图通过下面的awk命令根据筛选条件提取数据,但它没有起作用。你能解决这个问题吗?

代码语言:javascript
复制
awk -v RS='' -v ORS='\n\n' '/func: peak*down*HIL/' filename

输入:

代码语言:javascript
复制
func: peak_rec_head_HIL
sub: xyz
value: adc
log:path
close:date

func: peak_some_down_head_HIL
sub: xyz
value: adc
log:path
close:date

func: peak_another_one_down_head_HIL
sub: xyz
value: adc
log:path
close:date

func: peak_rec_head_HIL
sub: xyz
value: adc
log:path
close:date

func: peak_another_one_down_head_joy_HIL
sub: xyz
value: adc
log:path
close:date

预期产出:

代码语言:javascript
复制
func: peak_some_down_head_HIL
sub: xyz
value: adc
log:path
close:date

func: peak_another_one_down_head_HIL
sub: xyz
value: adc
log:path
close:date

func: peak_another_one_down_head_joy_HIL
sub: xyz
value: adc
log:path
close:date
EN

回答 1

Unix & Linux用户

回答已采纳

发布于 2022-09-19 09:24:22

问题是正则表达式。您需要将每个*替换为.*,以匹配子字符串之间任意数量的字符。

代码语言:javascript
复制
awk -v RS='' -v ORS='\n\n' '/func: peak.*down.*HIL/' file

每个*修改表达式前一部分的行为,允许它匹配0次或多次。表达式peak*down将匹配任何peadownpeakdownpeakkdownpeakkkdown等。

由于您的文件的格式与GNU撤销使用的格式相同,所以我将亲自使用recsel而不是awk来查询(或通常使用)您的数据:

代码语言:javascript
复制
recsel -e 'func ~ "peak.*down.*HIL"' file

与一般的文本处理工具相比,使用知道数据格式的工具通常更好(更容易、更健壮、更易于维护)。

票数 6
EN
页面原文内容由Unix & Linux提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://unix.stackexchange.com/questions/717792

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档