在awk中设置shell变量并重用
如何将shell变量传递给awk,设置它,在同一行的另一个awk中使用它并打印它 我想先将$0(所有字段)保存到变量中,解析$6(ABC 123456M123000)-获取“12300”,对其进行范围检查,如果满足,则打印所有字段($0) 第1部分:我正在尝试做:在awk中设置shell变量并重用,shell,variables,awk,Shell,Variables,Awk,如何将shell变量传递给awk,设置它,在同一行的另一个awk中使用它并打印它 我想先将$0(所有字段)保存到变量中,解析$6(ABC 123456M123000)-获取“12300”,对其进行范围检查,如果满足,则打印所有字段($0) 第1部分:我正在尝试做: line="hello" java class .... | awk -F, -v '{line=$0}' | awk 'begin my range check code' | if(p>100) print $line }
line="hello"
java class .... | awk -F, -v '{line=$0}' | awk 'begin my range check code' | if(p>100) print $line }
... | awk -F, '{split( $6, f, "M" )} f[2] > min' min=100
第2部分:
$6=“ABC 123456M123000”(我将分析的字符串)
将所有字段存储到变量中后,我可以使用以下方法解析$6:
awk 'begin {FS=" "} { print $2; len=length($2); p=substr($2,8,len)+0 ; print len,p ; if(p>100) print $line }'
但我的问题在第1部分:如何将$0存储到变量中,以便在检查完成后打印它们?不清楚为什么需要多次调用
awk
。根据您的描述,看起来您只是在尝试:
line="hello"
java class .... | awk -F, -v '{line=$0}' | awk 'begin my range check code' | if(p>100) print $line }
... | awk -F, '{split( $6, f, "M" )} f[2] > min' min=100
或者,如果无法在“M”上拆分,但需要使用substr(或其他方法提取所需值):
对于外壳:
java ... | while IFS= read -r line ; do
sixth=$(IFS=,; set -- $line; echo "$6")
val=${sixth:11}
(( $val > 100 )) && echo "$line"
done
那里有一些bash信息。我想打印所有字段$1、$2。。。不仅仅是min,所以我想用两个AWK。另外,“M”只是一个例子,可以有任何字符。这就是在解决方案中使用基于索引+1的substr的原因,但它可以/应该只使用awk内置的条件/操作处理:
awk-F,{split($6,F,“M”)}F[2]>min'