我的文本文件包含这样的字符串
abc,def,ghi,jkl,mno,pqr,stu,wxyz
我想把它做成这样
1.abc
2.def
3.ghi
4.jkl
5.mno
6.pqr
7.stu
8.wxyz
我怎样才能使用 sed 做到这一点?
答案1
你可以这样做
echo abc,def,ghi,jkl,mno,pqr,stu,wxyz | sed 's/,/\n/g' | nl -s "."
1.abc
2.def
3.ghi
4.jkl
5.mno
6.pqr
7.stu
8.wxyz
答案2
您可以使用 GNU awk
:
awk -v RS=',|\n' '{printf "%s.%s\n",NR,$0}' <<< "abc,def,ghi,jkl,mno,pqr,stu,wxyz"
答案3
几种 Perl 方法:
$ perl -F, -lne 'print ++$k.".$_" for @F' file
1.abc
2.def
3.ghi
4.jkl
5.mno
6.pqr
7.stu
8.wxyz
$ perl -pne 'chomp;s/([^,]+),*/++$k.".$1\n"/ge' file
1.abc
2.def
3.ghi
4.jkl
5.mno
6.pqr
7.stu
8.wxyz
和awk
:
$ awk -F, '{for(i=1;i<=NF;i++){print i"."$i}}' file
1.abc
2.def
3.ghi
4.jkl
5.mno
6.pqr
7.stu
8.wxyz
答案4
$ <file sed 's/,/\n/g' | sed '=' | paste -d . - -
1.abc
2.def
3.ghi
4.jkl
5.mno
6.pqr
7.stu
8.wxyz