
これは私の以前の質問に関連しています。BashとAWKを使用したテキストファイルの比較
ファイル1.txt
Name Col1 Col2 Col3
-----------------------
row1 1 4 7
row2 2 5 8
row3 3 6 9
ファイル2.txt
Name Col1 Col2 Col3
-----------------------
row1 1 4 7
row2 2 5 999
2つのファイルを比較する方法を見つけました。しかし、何らかの理由で私が望む結果を得ることはできません。これはファイルの比較に使用するコードです。
awk '
FNR < 2 { next }
FNR == NR {
for (i = 2; i <= NF; i++)
{
a[i,$1] = $i;
}
b[$1];
next;
}
($1 in b) {
for (i = 2; i <= NF; i++)
{
if (a[i,$1] == $i)
printf("%s->Col%d: %d vs %d: Equal\n", $1, i-1, a[i,$1], $i);
else
printf("%s->Col%d: %d vs %d: Not Equal\n", $1, i-1, a[i,$1], $i);
}
} ' file1.txt file2.txt
予想される結果:
row2->Col1: 1 vs 1: Equal
row2->Col2: 4 vs 4: Equal
row2->Col3: 7 vs 7: Equal
row1->Col1: 2 vs 2: Equal
row1->Col2: 5 vs 5: Equal
row1->Col3: 8 vs 999: Not Equal
実際の結果:
row2->Col1: 1 vs 1: Equal
row2->Col2: 4 vs 4: Equal
row2->Col3: 0 vs 7: Not Equal
row1->Col1: 2 vs 2: Equal
row1->Col2: 5 vs 5: Equal
row1->Col3: 0 vs 999: Not Equal
なぜゼロが出力の一部なのかわかりません。なぜゼロなのか知っている人はいますか?
編集:ここに問題があります。最初の for ループは一度だけ繰り返されます。なぜ?
答え1
エラー:変更
FNR == NR {
for (i = 2; i <= NF; i++)
{
a[i,$1] = $i;
b[$1];
next;
}
}
到着
FNR == NR {
for (i = 2; i <= NF; i++)
{
a[i,$1] = $i;
}
b[$1];
next;
}
next
後で電話してくださいi==2