如何在Linux命令行上解析CSV文件?
做这样的事情:
csvparse -c 2,5,6 filename
从所有行中提取列2、5和6中的字段。
它应该能够处理csv文件格式:https://www.rfc-editor.org/rfc/rfc4180,这意味着引用字段和根据适当的转义内部引号,因此对于包含3个字段的示例行:
field1,"field, number ""2"", has inner quotes and a comma",field3
因此,如果我为上面的行请求字段2,就会得到:
field, number "2", has inner quotes and a comma
我感谢有许多解决方案,Perl、Awk (等等)。对于这个问题,我想要一个本机bash命令行工具,它不需要我调用其他脚本环境或编写任何额外的代码(!)。
发布于 2009-06-30 14:36:04
我的FOSS CSV流编辑器CSVfix完全可以做您想做的事情。Windows有一个二进制安装程序,UNIX/Linux有一个可编译版本(通过makefile)。
发布于 2011-06-28 07:20:14
good工具真的很好。可在Debian / Ubuntu (apt-get install csvtool
)中获得。示例:
csvtool namedcol Account,Cost input.csv > output.csv
有关使用技巧,请参阅CSVTool手册页。
发布于 2013-11-07 03:02:24
正如@Jonathan在注释中所建议的那样,有一个python模块提供命令行工具csvfilter。它像剪切一样工作,但正确地处理CSV列引用:
csvfilter -f 1,3,5 in.csv > out.csv
如果您有python (而且您应该这样做),您可以简单地安装它,如下所示:
pip install csvfilter
https://stackoverflow.com/questions/1063125
复制相似问题