首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何通过Unix和awk命令将列中的值有条件地替换为同一行中特定列的值

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

Stack Overflow用户
提问于 2011-06-03 16:44:03
回答 2查看 6K关注 0票数 3

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

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

代码语言:javascript
复制
1 A . C .
2 C T . T
3 T C C .

有".“在第3到5列中。我想替换那些“。在第3-5列中,将第2列中的值放在同一行上。

你能给我指一下那方面的说明吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-06-03 17:01:50

这似乎满足了您的要求:

代码语言:javascript
复制
% 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吗?

票数 4
EN

Stack Overflow用户

发布于 2011-06-03 17:07:00

代码语言:javascript
复制
awk '{FS="\t"; for(i=3;i<=5;i++) if($i==".") $i=$2; print}' myfile.txt
票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6224869

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档