在 awk 命令中循环变量

在 awk 命令中循环变量

我有一个文本文件“Hessian_h2o_2z.log”包含以下内容:

            GX1        GY1        GZ1        GX2        GY2         GZ2        GX3        GY3        GZ3
GX1  0.5915206
GY1  0.0139938  0.0135051
GZ1 -0.0876734 -0.0846119  0.5301078
GX2 -0.5223003 -0.0025088  0.0157183  0.5399848
GY2  0.0078178 -0.0011236  0.0070395  0.0007403  0.0012737
GZ2 -0.0489795  0.0070395 -0.0441035 -0.0046382 -0.0079797  0.0499940
GX3 -0.0692203 -0.0114850  0.0719552 -0.0176845 -0.0085581  0.0536178  0.0869048
GY3 -0.0218115 -0.0123815  0.0775724  0.0017685 -0.0001501  0.0009402  0.0200430  0.0125316
GZ3  0.1366530  0.0775724 -0.4860043 -0.0110801  0.0009402 -0.0058905 -0.1255729 -0.0785126  0.4918948

我试图将第一列数字(文件中的第 2 列)中的每个值依次分配给变量 X,这是我到目前为止所拥有的:

a=1
b=1
a=$((a+1))
b=$((b+1))
X=`awk -v A=$a -v B=$b 'NR == A {print $B}' Hessian_h2o_2z.log`
Y=`awk -v A=$a -v B=$b 'NR == A {print $B}' Hessian_h2o_3z.log`

for var in $X
do
echo $var
done

然而这只是产生输出:

0.5915206

谁能解释为什么循环没有继续经过 NR == 2 和第 2 列?

注意,对于 shell 脚本来说相对较新,因此任何对脚本的帮助对于我想要实现的目标来说是不必要的长。

答案1

我认为,你原来的方法是有缺陷的。您可以在纯 shell 中执行此操作(对于少量(干净)数据)。

类似这样的方法可以帮到你:

while read -r VarName VarVal junk;
  do eval "$VarName=\"$VarVal\"";
done < /tmp/exampleData;
GX1="GY1"
GX1="0.5915206"
GY1="0.0139938"
GZ1="-0.0876734"
GX2="-0.5223003"
GY2="0.0078178"
GZ2="-0.0489795"
GX3="-0.0692203"
GY3="-0.0218115"
GZ3="0.1366530"

for i in $(cut -f1 -d ' ' /tmp/exampleData );
  do eval "echo $i → $"$i ;
done
cut -f1 -d ' ' /tmp/exampleData 
echo GX1 → $GX1
GX1 → 0.5915206
echo GY1 → $GY1
GY1 → 0.0139938
echo GZ1 → $GZ1
GZ1 → -0.0876734
echo GX2 → $GX2
...

相关内容