私のテキストファイルには、次の文字列が含まれています。
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