如何通过Unix和awk命令有条件地用同一行中特定列的值替换列中的值

时间:2011-06-03 08:44:03

标签: linux unix awk

我希望通过Unix和awk命令有条件地将列中的值替换为一个文件中同一行中特定列的值。

例如,我有myfile.txt(3行,5列,制表符分隔):

1 A . C .
2 C T . T
3 T C C .

有“。”在第3至5列中。我想替换那些“。”在第3 - 5列中,第2列中的值在同一行上。

你能告诉我任何指示吗?

2 个答案:

答案 0 :(得分:4)

这似乎符合您的要求:

% awk 'BEGIN {
     IFS = OFS = "\t"
  }
  {
     for (column = 3; column <= NF; ++column) {
        if ($column == ".") {
            $column = $2
        }
     }    
     print 
  }         
' test.tsv
1       A       A       C       A
2       C       T       C       T
3       T       C       C       T

你现在在awk上问了几个问题(并且没有接受答案!)。可以 我谦卑地建议a tutorial

答案 1 :(得分:4)

awk '{FS="\t"; for(i=3;i<=5;i++) if($i==".") $i=$2; print}' myfile.txt