Skip to main content

Fast, modern yaml parser and manipulator

Project description

Yamlium

A high-performance, dependency-free YAML parser for Python that preserves all YAML features including comments, anchors, and formatting.

📦 Features

  • 🎯 First-Class YAML Features: Preserves all YAML elements including comments, newlines, anchor names, and formatting
  • High Performance: 3x faster than PyYAML
  • 🧹 Zero Dependencies: Pure Python implementation with no external dependencies
  • 🛡️ Type Safety: Full type hints support
  • 🛠️ Rich API: Intuitive interface for manipulating YAML structures

🛠️ Installation

pip install yamlium

🚀 Quick Start

Basic Parsing

from yamlium import parse

# Parse a YAML string
yaml_str = """
name: John Doe
age: 30
address:
  street: 123 Main St
  city: Boston
"""
data = parse(yaml_str)

# Access values
print(data["name"])  # John Doe
print(data["address"]["city"])  # Boston

Preserving YAML Features

from yamlium import parse

yaml_str = """
# User configuration
user: &user_ref # Anchor definition
  name: Alice
  role: admin

# Reference to user
admin: *user_ref # Alias reference

""".lstrip()
yml = parse(yaml_str)

# The YAML structure is preserved when converting back including:
# - Anchor names
# - Comments
# - Newlines between objects
print(yml.to_yaml() == yaml_str)

Manipulating YAML

from yamlium import parse

yaml_str = """
users: # List of users
  - name: alice
    age: 25
  - name: Bob
    age: 30
  - name: charlie
"""
yml = parse(yaml_str)

# Modify values while preserving structure
for key, value, obj in yml.walk_keys():
    if key == "age":
        value += 1
    elif key == "name":
        # Using the string manipulation interface `.str`
        obj[key] = value.str.capitalize()

print(yml.to_yaml())

Working with Comments

Yamlium provides structured access to YAML comments via the comments attribute:

from yamlium import parse

yaml_str = """
app:
  # Database settings
  db_host: localhost # primary host
  # TODO: increase timeout

  # Cache config
  cache_ttl: 3600
"""
yml = parse(yaml_str)

# Access comments on a key
db_key = list(yml["app"].keys())[0]
print(db_key.comments.head)  # ['# Database settings']

# Access inline and foot comments on a value
db_value = yml["app"]["db_host"]
print(db_value.comments.line)  # '# primary host'
print(db_value.comments.foot)  # ['# TODO: increase timeout']

# Modify comments
db_value.comments.line = "# updated comment"

Comment types:

  • comments.head - comments directly above a node
  • comments.line - inline comment on the same line
  • comments.foot - comments below a node (before a blank line)

JSON Conversion

from yamlium import from_json, from_dict

# Convert from JSON string
json_str = '{"name": "test", "values": [1, 2, 3]}'
yaml_data = from_json(json_str)

# Convert from Python dict
python_dict = {"name": "test", "values": [1, 2, 3]}
yaml_data = from_dict(python_dict)

📚 API Reference

Parsing Functions

  • parse(input: str | Path) -> Mapping Parse a single YAML document
  • parse_full(input: str | Path) -> Document Parse multiple YAML documents
  • from_json(input: str | Path) -> Mapping | Sequence Convert JSON to YAML structure
  • from_dict(input: dict | list) -> Mapping | Sequence Convert Python dict/list to YAML structure

Yaml object functions

Given:

from yamlium import parse
yml = parse("my_yaml.yml")
  • yml.to_yaml() Convert to yaml string
  • yml.to_dict() Convert to python dictionary
  • yml.yaml_dump(destination="my_yaml.yml") Write directly to yaml file
  • yml.pprint() Pretty print the dictionary
  • yml.walk() Iterate through all yaml objects
  • yml.walk_keys() Iterate through all yaml keys

🔄 Comparison to PyYaml

While PyYaml solves the purpose of converting to dictionary perfectly fine, it completely ignores anything non-dictionary-conversion related in the yaml file.

Input yaml

# Anchor definition
dev: &default_config
  schedule: false
  my_config: [1, 2, 3]

staging:
  # Alias reference
  <<: *default_config
  schedule: true

Output

yamlium PyYaml
✅ Retaining structure❌ Changing structure
# Anchor definition
dev: &default_config
  schedule: false
  my_config: [1, 2, 3]

staging:
  # Alias reference
  <<: *default_config
  schedule: true
dev:
  my_config: &id001
  - 1
  - 2
  - 3
  schedule: false
staging:
  my_config: *id001
  schedule: true

🤝 Contributing

Contributions are welcome! Please feel free to submit Issues, Feature requests or Pull requests!

📄 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

yamlium-0.2.4.tar.gz (98.5 kB view details)

Uploaded Source

Built Distribution

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

yamlium-0.2.4-py3-none-any.whl (21.7 kB view details)

Uploaded Python 3

File details

Details for the file yamlium-0.2.4.tar.gz.

File metadata

  • Download URL: yamlium-0.2.4.tar.gz
  • Upload date:
  • Size: 98.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for yamlium-0.2.4.tar.gz
Algorithm Hash digest
SHA256 19ca7378d24d0026f711e0d3c594bdd6d2a808d1fd997035c397552fa84c86a7
MD5 02393c01f794d0392d287054d5592b5e
BLAKE2b-256 788bdf047f99ca90a44f798e5e9d3ae0933ac89ba972842cdb5aae616dc882e2

See more details on using hashes here.

Provenance

The following attestation bundles were made for yamlium-0.2.4.tar.gz:

Publisher: build_release.yml on erikmunkby/yamlium

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file yamlium-0.2.4-py3-none-any.whl.

File metadata

  • Download URL: yamlium-0.2.4-py3-none-any.whl
  • Upload date:
  • Size: 21.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for yamlium-0.2.4-py3-none-any.whl
Algorithm Hash digest
SHA256 e7a58c10e8f6e0ff73c78d4b4b8cf9fff15b301068677fa7575cd318c49e6d3b
MD5 ebbb2e4fd32f2fb0fb45ddfe2c96d0dd
BLAKE2b-256 25d8ecab37f501a4743cd8ca9cd1066a5fb930c9efe6318f5de6ab7edeeacdd0

See more details on using hashes here.

Provenance

The following attestation bundles were made for yamlium-0.2.4-py3-none-any.whl:

Publisher: build_release.yml on erikmunkby/yamlium

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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