我尝试使用awk检索文本的第四列,并在文件的第二行使用条件,但是我得到了一个空值作为输出。
这是我的输入文件内容,第1行:xxxx,第2行:GS*HP*IRX*029053964*20180611*114500
我需要在输入文件中查找条件HP*IRX*并打印值20180611 (第4列)
这是我的脚本
filedate=$(awk -F "*" '/HP*IRX/{print $4}' $file)
echo $filedate请告知我遗漏了什么..tnx!
发布于 2019-03-07 07:15:30
问题是*是正则表达式中的一个特殊字符。/HP*IRX/将匹配"H“,后跟零个或多个"P”,后跟"IRX“
你想要的
awk -F'*' '$2 == "HP" && $3 == "IRX" {print $5}'或者,如果您确实想要一个正则表达式
awk -F'*' '/\*HP\*IRX\*/ {print $5}'我在前面放了一个\*,这样你就不会用fooHP*IRX匹配一行
https://stackoverflow.com/questions/55033557
复制相似问题