ods2csv

Convert Open Document Spreadsheet ODS to CSV

https://hub.darcs.net/thielema/ods2csv

Version on this page:0.1
LTS Haskell 23.4:0.1.0.1
Stackage Nightly 2025-01-15:0.1.0.1
Latest on Hackage:0.1.0.1

See all snapshots ods2csv appears in

BSD-3-Clause licensed by Henning Thielemann
Maintained by [email protected]
This version can be pinned in stack with:ods2csv-0.1@sha256:04907ed5b40a09472c7e9e96dcc3879fd8cfa743d363b7531b9d4e9c880ec00b,2530

Module documentation for 0.1

There are no documented modules for this package.

Usually you would convert ODS to CSV via libreoffice --headless but this conflicts with running GUI instances of libreoffice and requires a full libreoffice installation and has incomprehensible CSV export command-line options and selection of individual tables is inferior.

This program quickly scans through a FODS or ODS document using a XML parser and watches only the necessary data. It does not interpret or evaluate the formula data, instead it assumes that the contained evaluated values are correct. This is true, if the file was saved from LibreOffice but might not be true if generated or manipulated by other tools.

You can feed generated CSV files to LaTeX datatool.sty, csvmidi, or csvreplace from Haskell package spreadsheet.

Example runs of the program:

ods2csv --list-tables input.ods
ods2csv --sheetnumber=1 input.ods >output.csv
ods2csv --sheetname="Table 2" --separator=TAB input.ods >output.tsv
ods2csv --sheetnumber=2 input.fods >output.csv
ods2csv --sheetnumber=2 <input.fods >output.csv

The program supports UTF-8 encoding for FODS/XML input, and applies Latin1 decoding otherwise. For writing CSV it uses the system's default encoding.

ToDo: Provide FODS parser as library function, maybe in spreadsheet.