首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >合并具有相同前三个字段的重复行

合并具有相同前三个字段的重复行
EN

Unix & Linux用户
提问于 2015-06-30 16:58:09
回答 2查看 140关注 0票数 2

我有下面的输入(一千行)。我需要一个sed命令将重复的行合并到相同的前三个字段中,这三个字段只添加不同的字段或删除"N/A":

代码语言:javascript
复制
D04005;4;279;0;0;SSM-4-1
D04005;5;40;0;0;SSM-5-1
LE040A;1;363;(26.3);N/A;SM-1-1
LE040A;1;363;(27.4);N/A;SM-1-2

预期产出:

代码语言:javascript
复制
D04005;4;279;0;0;SSM-4-1
D04005;5;40;0;0;SSM-5-1
LE040A;1;363;(26.3);(27.4);SM-1-1/SM-1-2
EN

回答 2

Unix & Linux用户

发布于 2015-06-30 19:30:42

TXR:

代码语言:javascript
复制
@(repeat)
@  (cases)
@id;@f2;@f3;@val1;@nil;@sm1
@id;@f2;@f3;@val2;@nil;@sm2
@    (do (put-line `@id;@f2;@f3;@val1;@val2;@sm1/@sm2`))
@  (or)
@line
@    (do (put-line line))
@  (end)
@(end)

$ txr data.txr data
D04005;4;279;0;0;SSM-4-1
D04005;5;40;0;0;SSM-5-1
LE040A;1;363;(26.3);(27.4);SM-1-1/SM-1-2
票数 1
EN

Unix & Linux用户

发布于 2015-06-30 22:35:19

代码语言:javascript
复制
sed -r ':a;N;s!;N/A!!g;s/^(([^;]*;){3})(.*)\n\1/\1\3;/;T;s!^(([^S][^;]*;){3,})(S*SM-[^;]*);(([^S][^;]*;){1,})(.*)!\1\4\3/\6!;ta' inputfile

尽管对输出中只有6个字段的注释的隐含数学表示只有对,但这是一个循环版本,在匹配时会更改输出SM-1-1/SM-1-2。

票数 1
EN
页面原文内容由Unix & Linux提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://unix.stackexchange.com/questions/213121

复制
相关文章

相似问题

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