我正在寻找一种方法将xlsx文件转换为Linux上的csv文件。

我不想使用PHP/Perl或类似的东西,因为我正在处理数百万行,所以我需要一些快速的东西。我在Ubuntu repos上找到了一个名为xls2csv的程序,但它只会转换xls (Office 2003)文件(我目前正在使用),但我需要对更新的Excel文件的支持。

什么好主意吗?


当前回答

使用csvkit

in2csv data.xlsx > data.csv

详情请查阅他们优秀的文档

其他回答

在bash中,我使用这个libreoffice命令来转换当前目录下的所有xlsx文件:

for i  in *.xlsx; do  libreoffice --headless --convert-to csv "$i" ; done

在执行之前关闭所有Libre Office打开实例,否则它将无声地失败。

该命令负责文件名中的空格。

几年后我又试了一次,但没有成功。这篇文章给出了一些提示,但最快的解决方案是作为根用户运行(或运行sudo libreoffice)。不优雅,但很快。

在Windows中使用命令scalc.exe

你可以使用LibreOffice:

libreoffice --headless --convert-to csv $filename --outdir $outdir

出于我不清楚的原因,您可能需要使用sudo运行此程序。你可以让LibreOffice使用sudo而不需要密码,添加这行到你的sudoers文件:

users ALL=(ALL) NOPASSWD: libreoffice

使用csvkit

in2csv data.xlsx > data.csv

详情请查阅他们优秀的文档

如果你已经有了一个桌面环境,那么我相信Gnumeric / LibreOffice会工作得很好,但是在一个无头服务器(比如Amazon Web Services)上,它们需要几十个依赖项,你也需要安装这些依赖项。

我找到了这个Python替代品:

https://github.com/dilshod/xlsx2csv

$ easy_install xlsx2csv
$ xlsx2csv file.xlsx > newfile.csv

安装只需2秒钟,工作起来很有魅力。

如果你有多个表,你可以一次全部导出,或者一次导出一个:

$ xlsx2csv file.xlsx --all > all.csv
$ xlsx2csv file.xlsx --all -p '' > all-no-delimiter.csv
$ xlsx2csv file.xlsx -s 1 > sheet1.csv

他还链接了几个用Bash、Python、Ruby和Java构建的替代方案。

如果.xlsx文件有很多表,-s标志可以用来获得你想要的表。例如:

xlsx2csv "my_file.xlsx" -s 2 second_sheet.csv

Second_sheet.csv将包含my_file.xlsx中第二表的数据。