将文本文件中的行分组,并将相应的行聚合到列
现有文字文件
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
提前致谢
答案 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