我有一个文本文件:
ifile.txt
1 4 22.0 3.3 2.3
2 2 34.1 5.4 2.3
3 2 33.0 34.0 2.3
4 12 3.0 43.0 4.4
我想将其转换为csv文件:
ofile.txt
ID,No,A,B,C
1,4,22.0,3.3,2.3
2,2,34.1,5.4,2.3
3,2,33.0,34.0,2.3
4,12,3.0,43.0,4.4
我正在尝试这个,但没有得到结果。
(echo "ID,No,A,B,C" ; cat ifile.txt) | sed 's/<space>/<comma>/g' > ofile.csv
答案 0 :(得分:17)
awk
在这里可能有些过分。恕我直言,使用tr
进行这样的直接替换要简单得多:
$ cat ifile.txt | tr -s '[:blank:]' ',' > ofile.txt
答案 1 :(得分:17)
只有sed而没有别的
sed 's/ \+/,/g' ifile.txt > ofile.csv
cat ofile.csv
1,4,22.0,3.3,2.3
2,2,34.1,5.4,2.3
3,2,33.0,34.0,2.3
4,12,3.0,43.0,4.4
答案 2 :(得分:3)
这是awk版本
awk 'BEGIN{print "ID,No,A,B,C"}{print $1","$2","$3","$4","$5}' ifile.txt
输出:
ID,No,A,B,C
1,4,22.0,3.3,2.3
2,2,34.1,5.4,2.3
3,2,33.0,34.0,2.3
4,12,3.0,43.0,4.4
答案 3 :(得分:2)
试试这个..
tr -s " " < ifile.txt | sed 's/ /,/g' > ofile.txt
<强>输出强>
1,4,22.0,3.3,2.3
2,2,34.1,5.4,2.3
3,2,33.0,34.0,2.3
4,12,3.0,43.0,4.4
答案 4 :(得分:2)
一种可能性,不一定是最好的,是:
sed -e '1i\
ID,No,A,B,C' -e 's/[[:space:]]\{1,\}/,/g' ifile.txt
在第1行之前插入标题;将一个或多个类空格字符的每个序列更改为逗号。传统中必须使用换行符(POSIX标准 - 在本例中为BSD或Mac OS X)sed
; GNU sed
允许您使用:
/opt/gnu/bin/sed -e '1i\' -e 'ID,No,A,B,C' -e 's/[[:space:]]\{1,\}/,/g'
输出:
ID,No,A,B,C
1,4,22.0,3.3,2.3
2,2,34.1,5.4,2.3
3,2,33.0,34.0,2.3
4,12,3.0,43.0,4.4
或者,更简单地说,让sed
处理文件并使用echo
添加标题,就像您在大纲中所做的那样:
{
echo "ID,No,A,B,C"
sed -e 's/[[:space:]]\{1,\}/,/g' ifile.txt
} > ofile.txt
经过审核,这可能是我使用的。
答案 5 :(得分:1)
只需使用 awk 命令即可。
awk '{
printf("%d, %d, %.1lf, %.1lf,%.1lf\n", $1,$2,$3,$4,$5);
}' input.txt > output.csv