Skip to main content

Multi-structure YAML config loader 🐍🔌

Project description

setconfig 🔌

[!TIP] Don't forget to star this repo if you like it! ⭐

Some developers prefer to use @dataclass while others prefer BaseModel. This holy war is not going to end soon. So now they can use the same loader and config file in different parts/microservices of one project.

Currently supported:

Features:

  • Loading from streams
  • Multiple config files
  • Value overriding
  • Tuple-friendly

Installation

pip install setconfig

Usage sample

Dataclass, full sample here

from dataclasses import dataclass
from setconfig import load_config

@dataclass
class Node:
    host: str
    port: int

@dataclass
class Config:
    nodes: list[Node]

config = load_config('config.yaml', into=Config)

print(config)
# >>> Config(nodes=[Node(host='1.1.1.1', port=1000)])
print(config.nodes[0].host)
# >>> '1.1.1.1'

Pydantic, full sample here

from pydantic import BaseModel
from setconfig import load_config

class Node(BaseModel):
    host: str
    port: int

class Config(BaseModel):
    nodes: list[Node]

config = load_config('config.yaml', into=Config)

print(config)
# >>> Config(nodes=[Node(host='1.1.1.1', port=1000)])
print(config.nodes[0].host)
# >>> '1.1.1.1'

SimpleNamespace, full sample here

from setconfig import load_config

config = load_config('config.yaml')

print(config)
# >>> Config(nodes=[Node(host='1.1.1.1', port=1000)])
print(config.nodes[0].host)
# >>> '1.1.1.1'

Features

Loading from string/StringIO/etc

from setconfig import load_config_stream

config = load_config_stream('done: true')

Multiple config files, full sample here

config = load_config('config.base.yaml', 'config.dev.yaml', 'config.feature-x.yaml', into=Config)

Configs are processed in the order they are passed to load_config (from left to right), where last overrides the previous ones

Value overriding, full sample here

config = load_config('config.yaml', into=Config, override={'timeout': 10})

Extra parsing params

config = load_config('config.yaml', into=Config, check_types=False)

Where check_types is a dacite flag, see https://github.com/konradhalas/dacite#type-checking

Tuple-friendly

There is known issue in dacite that raises type error when loading list into tuple. Pull request with fix is ready since May 2023, but not merged yet... That's why setconfig has its own fix

FAQ

Why only YAML?

There should be one-- and preferably only one --obvious way to do it

(c) Zen of Python

I want to use structure from X package

Create an issue or PR :)

More

PyPI: https://pypi.org/project/setconfig

Repository: https://github.com/abionics/setconfig

Developer: Alex Ermolaev (Abionics)

Email: abionics.dev@gmail.com

License: MIT (see LICENSE.txt)

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

setconfig-1.4.1.tar.gz (4.9 kB view details)

Uploaded Source

File details

Details for the file setconfig-1.4.1.tar.gz.

File metadata

  • Download URL: setconfig-1.4.1.tar.gz
  • Upload date:
  • Size: 4.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.6

File hashes

Hashes for setconfig-1.4.1.tar.gz
Algorithm Hash digest
SHA256 fc2f8e5dc2d640ae38e5e9376bbe8809041d62e1322150b8481e4fe0f333245b
MD5 e24c45450dffc9d99b3ef4981b2b5317
BLAKE2b-256 935b274ad022ccee6879332e8aa8c6a41194f544807662bb9510c5f10064d947

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