3

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

现有文本文件

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

提前致谢

4

2 回答 2

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
于 2012-07-09T06:47:39.343 回答
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
于 2012-07-09T06:50:30.307 回答