Linuxでは、各行を2倍に増やし、各行の数を異なるように変更する方法は?

Linuxでは、各行を2倍に増やし、各行の数を異なるように変更する方法は?

入力ファイルは次のとおりです。

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

おすすめ記事