4

次のようなファイルがあります。

ID1 ID2 3
ID2 ID3 3
ID4 ID5 3
ID6 ID7 4
ID8 ID9 4
ID8 ID6 4

そして、私はそれを次のように変更したいと思います:

ID1 ID2 1
ID2 ID3 1
ID4 ID5 1
ID6 ID7 2
ID8 ID9 2
ID8 ID6 2

そこで、3列目と4列目をそれぞれ1列と2列に変更したいと思います。非常に大きなファイルに対してこれを行う最も効率的な方法は何ですか?よろしくお願いします!

4

2 に答える 2

6
awk '{ $3 -= 2; print }' filename >new_filename 

または、本当に3と4だけに触れたい場合:

awk '{ if ( $3 == 3 ) { $3 = 1 } else if ( $3 == 4 ) { $3 = 2 }; print}' filename >new_filename
于 2012-05-17T18:21:03.273 に答える
1

3番目の列が常に最後の列であると仮定します。

sed 's/\([^0-9]\)3$/\11/;s/\([^0-9]\)4$/\12/'
于 2012-05-17T18:22:42.050 に答える