对文本文件中的行进行分组,并将相应的行聚合到列

时间:2012-07-09 06:26:13

标签: bash awk

将文本文件中的行分组,并将相应的行聚合到列

现有文字文件

John|Life
John|Temp
John|Admin
Peter|Life
Peter|Admin
Matt|Life
Matt|Admin
Matt|Temp

所需的输出

John|Life,Temp,Admin
Peter|Life,Admin
Matt|Life,Temp,Admin

提前致谢

2 个答案:

答案 0 :(得分:4)

命令

awk -F '|' '
$1==x{
    printf ",%s", $2
    next
}
{
    x=$1
    printf "\n%s|%s", $1, $2
}
END {
    printf "\n"
}' input.txt

结果

John|Life,Temp,Admin
Peter|Life,Admin
Matt|Life,Admin,Temp

答案 1 :(得分:1)

sed解决方案:

sed -e ':a;$!{N;ba};:p' \
 -e 's/^\([^|\n]*|\)\([^\n]*\)\(.*\n\)\1\([^|\n]*\)/\1\2,\4\3/' \
 -e 'tp;s/\n*\n/\n/;P;D;bp' filename