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を過ぎて続行しない理由を説明できる人はいますか?

ちなみに、シェルスクリプトは比較的新しいものなので、スクリプトのヘルプは私が達成しようとしている目標に比べて不必要に長いことに注意してください。

ベストアンサー1

私の考えでは、あなたの元のアプローチに欠陥があります。 (少量の(クリーン)データの場合)純粋なシェルでこれを行うことができます。

次のようなものが役に立ちます。

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
...

おすすめ記事