入力ファイルは次のとおりです。
1 0 0 000 3444
2 3 3 456 6875
3 0 0 023 3300
4 2 2 211 1000
まず、各行に2つのコピーが必要です。
1 0 0 000 3444
1 0 0 000 3444
2 3 3 456 6875
2 3 3 456 6875
3 0 0 023 3300
3 0 0 023 3300
4 2 2 211 1000
4 2 2 211 1000
2番目:各行の最初のコピーでは、3は2に変わり、4は1に変更し、各行の2番目のコピーでは3を1に変更し、4を2に変更する必要があります(最初の列は行名)と行番号は変更しないでください)。したがって、最終出力は次のようになります。
1 0 0 000 2111
1 0 0 000 1222
2 2 2 156 6875
2 1 1 256 6875
3 0 0 022 2200
3 0 0 021 1100
4 2 2 211 1000
4 2 2 211 1000
どんな提案がありますか?私はこれを試しましたが、うまくいきません。
awk '
{ tmp = $2; gsub("3", "2", $2); gsub("4", "1", $2); print}
{ $2 = tmp; gsub("3", "1", $2); gsub("4", "2", $2); print}
' < input > output
ベストアンサー1
各行を2倍にする方法:ねえ...
2番目の要求では、最初のフィールドと行全体を変数に保存し、最初の変更を実行し、最初のフィールドを初期値に設定して印刷し、行の内容を復元して2番目の変更を実行します。最初のフィールドをもう一度初期値に設定して印刷します。
awk '{t=$1;l=$0;gsub(/3/, "2");gsub(/4/, "1");$1=t;print}
{$0=l;gsub(/3/, "1");gsub(/4/, "2");$1=t;print}' infile