我正在尝试通过以下命令根据过滤条件提取数据awk
,但它不起作用。你能解决这个问题吗?
awk -v RS='' -v ORS='\n\n' '/func: peak*down*HIL/' filename
输入:
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
预期输出:
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
问题是正则表达式。您需要将每个替换
*
为.*
匹配子字符串之间任意数量的任意字符。每个都
*
修改表达式前一部分的行为,使其匹配零次或多次。该表达式peak*down
将匹配peadown
,peakdown
,peakkdown
等中的任何一个peakkkdown
。由于您的文件格式与GNU recutils使用的格式相同,我个人会使用
recsel
而不是awk
查询(或通常使用)您的数据:使用了解数据格式的工具通常比使用通用文本处理工具更好(更容易、更健壮、更容易维护)。