Tomli-W: A Minimal TOML Writer
Tomli-W is a pure Python library designed for writing TOML (Tom's Obvious, Minimal Language) documents. It acts as the write-only counterpart to the `tomli` parser (which is also the basis for the `tomllib` standard library module in Python 3.11+). It is fully compatible with TOML v1.0.0 and focuses on simplicity and correctness in output. The library maintains an active status with periodic updates.
Warnings
- breaking `tomli-w` requires Python 3.9 or newer. Attempts to use it on older Python versions will result in an `ImportError` or `SyntaxError`.
- gotcha `tomli-w` does not preserve comments, original ordering (beyond respecting input dictionary order), or custom whitespace. For style-preserving writing (e.g., maintaining comments, specific indentation), `tomlkit` is a recommended alternative.
- gotcha The library does not automatically validate the generated TOML. If the input data contains non-standard types or structures that could result in invalid TOML (e.g., objects whose `__str__` method produces invalid TOML syntax), `tomli-w` will write it without raising an error. It's recommended to validate the output by parsing it with a TOML reader like `tomli.loads()` (or `tomllib.loads()` in Python 3.11+).
- gotcha When writing TOML to a file using `tomli_w.dump()`, the file must be opened in binary write mode (`'wb'`). Using text mode (`'w'`) can lead to encoding issues (e.g., incorrect UTF-8 handling) or incorrect newline handling.
- gotcha By default, `tomli-w` avoids writing multi-line strings (using triple quotes in TOML) even if the Python string value contains newlines. This design choice aims to ensure lossless parse/write round-trips for TOML strings where exact byte representation matters.
- gotcha `tomli-w` is exclusively for writing TOML and does not provide any functionality for parsing or reading TOML documents.
Install
-
pip install tomli-w
Imports
- tomli_w
import tomli_w
Quickstart
import tomli_w
import os
# Example data to write
doc = {
"title": "My Awesome Project",
"owner": {
"name": "Alice Example",
"organization": "Example Corp",
"dob": "1979-05-27T07:32:00-08:00"
},
"database": {
"server": "192.168.1.1",
"ports": [8001, 8001, 8002],
"connection_max": 5000,
"enabled": True
},
"servers": {
"alpha": {
"ip": "10.0.0.1",
"dc": "eqdc10"
},
"beta": {
"ip": "10.0.0.2",
"dc": "eqdc10"
}
}
}
# 1. Write to a string
toml_string = tomli_w.dumps(doc)
print("--- TOML String ---")
print(toml_string)
# 2. Write to a file
file_path = "config.toml"
try:
with open(file_path, "wb") as f:
tomli_w.dump(doc, f)
print(f"\n--- TOML written to {file_path} ---")
with open(file_path, "r") as f_read:
print(f_read.read())
except Exception as e:
print(f"Error writing TOML to file: {e}")
finally:
if os.path.exists(file_path):
os.remove(file_path) # Clean up