Unix代码想要更改列值

时间:2012-05-17 18:15:42

标签: bash unix

我有一个看起来像这样的文件:

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列的所有3和4分别改为1和2。对于一个非常大的文件,最有效的方法是什么?非常感谢提前!

2 个答案:

答案 0 :(得分: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

答案 1 :(得分:1)

假设第三列始终是最后一列:

sed 's/\([^0-9]\)3$/\11/;s/\([^0-9]\)4$/\12/'