Skip to main content

Generate an OpenDocument Format .ods file from json or yaml file

Project description

odsgenerator, an .ods generator.

Generate an OpenDocument Format .ods file from a .json or .yaml file.

When used as a script, odsgenerator parses a JSON or YAML description of tables and generates an ODF document using the odfdo library.

When used as a library, odsgenerator parses a Python description of tables and returns the ODF content as bytes (ready to be saved as a valid ODF document).

  • The content description can be minimalist: a list of lists of lists,
  • or description can be complex, allowing styles at row or cell level.

See also https://github.com/jdum/odsparsator which is doing the reverse operation, .osd to .json.

odsgenerator is a Python3 package, using the odfdo library. Current version requires Python >= 3.9, see prior versions for older environments.

Project: https://github.com/jdum/odsgenerator

Author: jerome.dumonteil@gmail.com

License: MIT

Installation

Installation from Pypi (recommended):

pip install odsgenerator

Installation from sources (requiring setuptools):

pip install .

CLI usage

odsgenerator [-h] [--version] input_file output_file

arguments

input_file: input file containing data in JSON or YAML format

output_file: output file, .ods file generated from the input

Use odsgenerator --help for more details about input file parameters and look at examples in the tests folder.

Usage from python code

import odsgenerator

content = odsgenerator.ods_bytes([[["a", "b", "c"], [10, 20, 30]]])
with open("sample.ods", "wb") as file:
    file.write(content)

The resulting .ods file loaded in a spreadsheet:

spreadsheet screnshot

Another example with more parameters:

import odsgenerator

content = odsgenerator.ods_bytes(
    [
        {
            "name": "first tab",
            "style": "cell_decimal2",
            "table": [
                {
                    "row": ["a", "b", "c"],
                    "style": "bold_center_bg_gray_grid_06pt",
                },
                [10, 20, 30],
            ],
        }
    ]
)
with open("sample2.ods", "wb") as file:
    file.write(content)

The .ods file loaded in a spreadsheet, with gray background on first line:

spreadsheet screnshot

Principle

  • A document is a list or dict containing tabs,
  • a tab is a list or dict containing rows,
  • a row is a list or dict containing cells.

Documentation

See in the `./docL folder:

  • html/odsgenerator.html
  • tutorial.json or tutorial.yml and tutorial.ods

License

This project is licensed under the MIT License (see the LICENSE file for details).

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

odsgenerator-1.8.0.tar.gz (10.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

odsgenerator-1.8.0-py3-none-any.whl (10.3 kB view details)

Uploaded Python 3

File details

Details for the file odsgenerator-1.8.0.tar.gz.

File metadata

  • Download URL: odsgenerator-1.8.0.tar.gz
  • Upload date:
  • Size: 10.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.12.0

File hashes

Hashes for odsgenerator-1.8.0.tar.gz
Algorithm Hash digest
SHA256 c64e40ad7792ed59d76cd06480704a9442306bd3abd0a7345af90872fda043c1
MD5 f276e121dfa76422a5f451071a94113d
BLAKE2b-256 47e52b57c5cfd7d75a65fd25ff03fb9d39966168fd34d291021663a0ef44e0af

See more details on using hashes here.

File details

Details for the file odsgenerator-1.8.0-py3-none-any.whl.

File metadata

  • Download URL: odsgenerator-1.8.0-py3-none-any.whl
  • Upload date:
  • Size: 10.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.12.0

File hashes

Hashes for odsgenerator-1.8.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6f2e8f329d04d392f4d654f78b0f9c791ad8aa915365562cee98a45dd8c53c22
MD5 8897de66be38265e7bc609841b581e99
BLAKE2b-256 801fc7722c9a4cdabd6a0c01a076ddcd03755441a4fde038970888c7183f8ba7

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page