首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在Linux命令行上解析CSV文件?

如何在Linux命令行上解析CSV文件?
EN

Stack Overflow用户
提问于 2009-06-30 11:16:02
回答 12查看 62.3K关注 0票数 40

如何在Linux命令行上解析CSV文件?

做这样的事情:

代码语言:javascript
运行
复制
csvparse -c 2,5,6 filename

从所有行中提取列2、5和6中的字段。

它应该能够处理csv文件格式:https://www.rfc-editor.org/rfc/rfc4180,这意味着引用字段和根据适当的转义内部引号,因此对于包含3个字段的示例行:

代码语言:javascript
运行
复制
field1,"field, number ""2"", has inner quotes and a comma",field3

因此,如果我为上面的行请求字段2,就会得到:

代码语言:javascript
运行
复制
field, number "2", has inner quotes and a comma

我感谢有许多解决方案,Perl、Awk (等等)。对于这个问题,我想要一个本机bash命令行工具,它不需要我调用其他脚本环境或编写任何额外的代码(!)。

EN

回答 12

Stack Overflow用户

回答已采纳

发布于 2009-06-30 14:36:04

我的FOSS CSV流编辑器CSVfix完全可以做您想做的事情。Windows有一个二进制安装程序,UNIX/Linux有一个可编译版本(通过makefile)。

票数 20
EN

Stack Overflow用户

发布于 2011-06-28 07:20:14

good工具真的很好。可在Debian / Ubuntu (apt-get install csvtool)中获得。示例:

代码语言:javascript
运行
复制
csvtool namedcol Account,Cost input.csv > output.csv

有关使用技巧,请参阅CSVTool手册页

票数 24
EN

Stack Overflow用户

发布于 2013-11-07 03:02:24

正如@Jonathan在注释中所建议的那样,有一个python模块提供命令行工具csvfilter。它像剪切一样工作,但正确地处理CSV列引用:

代码语言:javascript
运行
复制
csvfilter -f 1,3,5 in.csv > out.csv

如果您有python (而且您应该这样做),您可以简单地安装它,如下所示:

代码语言:javascript
运行
复制
pip install csvfilter

更多信息请访问https://github.com/codeinthehole/csvfilter/

票数 13
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1063125

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档