我正在寻找一种方法将xlsx文件转换为Linux上的csv文件。
我不想使用PHP/Perl或类似的东西,因为我正在处理数百万行,所以我需要一些快速的东西。我在Ubuntu repos上找到了一个名为xls2csv的程序,但它只会转换xls (Office 2003)文件(我目前正在使用),但我需要对更新的Excel文件的支持。
什么好主意吗?
我正在寻找一种方法将xlsx文件转换为Linux上的csv文件。
我不想使用PHP/Perl或类似的东西,因为我正在处理数百万行,所以我需要一些快速的东西。我在Ubuntu repos上找到了一个名为xls2csv的程序,但它只会转换xls (Office 2003)文件(我目前正在使用),但我需要对更新的Excel文件的支持。
什么好主意吗?
当前回答
您可以使用libreoffice将.xlsx文件转换为CSV
$ libreoffice --headless --convert-to csv ABC.xlsx
headless表示我们不需要GUI。
其他回答
如果你可以运行Java命令行,那么你可以用Apache POI HSSF的Excel Extractor来做。它有一个主方法,说它是命令行提取器。这个好像把所有东西都倒出来了。他们指出了这个转换为CSV的例子。在运行它之前,你必须编译它,但它也有一个主方法,所以你不应该做很多编码本身使它工作。
另一种可能可行但需要在另一端做一些工作的方法是将Excel文件转换为Excel XML数据或XML电子表格,不管微软现在怎么称呼这种格式。它将为你打开一个充满机会的全新世界,让你以自己想要的方式来切割它。
如果.xlsx文件有很多表,-s标志可以用来获得你想要的表。例如:
xlsx2csv "my_file.xlsx" -s 2 second_sheet.csv
Second_sheet.csv将包含my_file.xlsx中第二表的数据。
https://gist.github.com/scottming/99c09685360376d4cac2de7c891e8050
您可以使用这个脚本。先添加依赖项:
Pip3安装pandas XLRD openpyxl
然后调用脚本:python3 getsheets.py <file.xlsx>
使用Gnumeric电子表格应用程序,其中有一个命令行实用程序称为ssconvert,确实超级简单:
find . -name '*.xlsx' -exec ssconvert -T Gnumeric_stf:stf_csv {} \;
这样就完成了!
正如其他人所说,libreoffice可以将xls文件转换为csv文件。对我来说,问题在于纸张的选择。
这个libreoffice Python脚本在将单个表格转换为CSV方面做得很好。
用法是:
./libreconverter.py File.xls:"Sheet Name" output.csv
唯一的缺点(在我这边)是——无头似乎不管用。我有一个LO窗口,显示了一秒钟,然后退出。 这对我来说没问题,这是唯一能快速完成工作的工具。