我有一个文本文件“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
...