分页: 1 / 1

[讨论]大家来看看这个文本要怎么解决!

发表于 : 2008-05-14 7:23
coldweb
文件名为DATA内容如下:
A B C X1
A B C S2
A B C X3
D F T Y1
D F T S1
M N U K2
M N U K3
我想将文件处理成如下格式:
A B C 3
X1
S2
X3
D F T 2
Y1
S1
M N U 2
K2
K3
即先先将每行前面三个一样的先归类,统计出现的次数,然后在分别显示,后面的不同内容,请问这个应该怎么写SHELL。

发表于 : 2008-05-14 12:23
bones7456

代码: 全选

$ awk '{a[$1,$2,$3]++;b[$1,$2,$3]=b[$1,$2,$3] "\n" $4} END{for(i in a){j=i;gsub(/\x1c/," ",j);print j,a[i],b[i]}}' DATA
A B C 3 
X1
S2
X3
D F T 2 
Y1
S1
M N U 2 
K2
K3

发表于 : 2008-05-14 13:18
bones7456
这样应该更优雅一点:

代码: 全选

$ awk 'BEGIN{SUBSEP=" "}{a[$1,$2,$3]++;b[$1,$2,$3]=b[$1,$2,$3] "\n" $4}END{for(i in a)print i,a[i],b[i]}' DATA
M N U 2 
K2
K3
A B C 3 
X1
S2
X3
D F T 2 
Y1
S1