我正在尝试使用awk并在文件第二行上使用条件来检索文本的第四列,但是我得到了一个空白值作为输出。
这是我的输入文件内容
第一行:xxxx
第二行:GS*HP*IRX*029053964*20180611*114500
我需要在输入文件中查找条件HP*IRX*
,然后打印值20180611
(第4列)
这是我的脚本
filedate=$(awk -F "*" '/HP*IRX/{print $4}' $file)
echo $filedate
请告知我所缺少的..tnx!
答案 0 :(得分:1)
问题在于*
是正则表达式中的特殊字符。 /HP*IRX/
将匹配“ H”,后跟零个或多个“ P” ,后跟“ IRX”
你想要
awk -F'*' '$2 == "HP" && $3 == "IRX" {print $5}'
或者,如果您真的想要正则表达式
awk -F'*' '/\*HP\*IRX\*/ {print $5}'
我在前面放置了\*
,所以您与fooHP*IRX
的行不匹配