A simple YAML configuration management library
Project description
PCF Config
A simple and flexible YAML configuration management library for Python applications. PCF Config provides an easy way to manage configuration files with support for nested keys, default values, and read/write operations.
Features
- 🔧 Simple API: Easy-to-use methods for getting and setting configuration values
- 🏗️ Nested Keys: Support for dot-notation nested key access (e.g.,
database.host) - 🛡️ Default Values: Graceful handling of missing keys with default values
- 🔄 Hot Reload: Reload configuration files at runtime
- ✏️ Read/Write: Set configuration values and save to files
- 🪶 Lightweight: Minimal dependencies (only PyYAML required)
- 🎯 Type Hints: Full type hint support for better IDE experience
- 🚀 No Singleton: Multiple instances supported for flexibility
Installation
Install from PyPI:
pip install pcf-config
Quick Start
- Create a configuration file (
config.yaml):
database:
host: localhost
port: 5432
name: myapp
api:
host: 0.0.0.0
port: 8000
debug: true
- Use in your Python code:
from pcf_config import Config
# Create config instance with file path
config = Config("config.yaml")
# Get configuration values
db_host = config.get("database.host") # Returns: "localhost"
db_port = config.get("database.port") # Returns: 5432
# Get with default values
redis_host = config.get("redis.host", "localhost")
timeout = config.get("api.timeout", 30)
# Set new values
config.set("database.timeout", 30)
config.set("api.debug", True)
# Save changes to file
config.save()
print(f"Database: {db_host}:{db_port}")
print(f"Redis: {redis_host}")
API Reference
Config Class
The main class for configuration management:
from pcf_config import Config
# Create config instance with file path
config = Config("config.yaml")
# Get configuration values
value = config.get("key")
value_with_default = config.get("key", "default")
# Set configuration values
config.set("new.key", "value")
# Save changes to file
config.save()
# Reload from file
config.reload()
# Check if key exists
if config.has_key("key"):
print("Key exists")
Methods
__init__(config_file: str)
Initialize Config instance with configuration file path.
Parameters:
config_file(str): Path to the YAML configuration file
get(key: str, default: Any = ...) -> Any
Get configuration value by key. Supports nested keys using dot notation.
Parameters:
key(str): Configuration key, supports dot notation for nested keysdefault(Any): Default value if key doesn't exist
Returns:
Any: The configuration value or default
Raises:
KeyError: If the key doesn't exist and no default is provided
set(key: str, value: Any) -> None
Set configuration value. Creates nested structure if needed.
Parameters:
key(str): Configuration key, supports dot notation for nested keysvalue(Any): Value to set
save() -> None
Save current configuration to the file.
reload() -> None
Reload the configuration file from disk.
has_key(key: str) -> bool
Check if a configuration key exists.
Parameters:
key(str): Configuration key to check
Returns:
bool: True if key exists, False otherwise
Configuration File Location
PCF Config requires you to specify the configuration file path when creating a Config instance:
config = Config("path/to/your/config.yaml")
Examples
Basic Usage
from pcf_config import Config
# Create config instance
config = Config("config.yaml")
# config.yaml:
# app:
# name: "My App"
# version: "1.0.0"
# debug: true
# database:
# host: "localhost"
# port: 5432
app_name = config.get("app.name") # "My App"
app_version = config.get("app.version") # "1.0.0"
db_host = config.get("database.host") # "localhost"
# Using defaults for missing keys
cache_ttl = config.get("cache.ttl", 3600) # 3600 (default)
debug_mode = config.get("app.debug", False) # True (from config)
Error Handling
from pcf_config import Config
config = Config("config.yaml")
try:
api_key = config.get("api.secret_key")
except KeyError:
print("API key not configured!")
api_key = None
# Or use default values to avoid exceptions
api_key = config.get("api.secret_key", None)
if not api_key:
print("Warning: API key not configured!")
Hot Reload
from pcf_config import Config
config = Config("config.yaml")
# Initial load
print(config.get("app.name"))
# Modify config.yaml file externally...
# Reload configuration
config.reload()
print(config.get("app.name")) # Updated value
Read/Write Operations
from pcf_config import Config
config = Config("config.yaml")
# Read existing values
db_host = config.get("database.host")
# Set new values
config.set("database.timeout", 30)
config.set("api.rate_limit", 1000)
# Save changes to file
config.save()
# Verify changes
print(config.get("database.timeout")) # 30
print(config.get("api.rate_limit")) # 1000
Complex Configuration
# config.yaml
app:
name: "My Application"
version: "2.1.0"
database:
primary:
host: "db1.example.com"
port: 5432
credentials:
username: "admin"
password: "secret"
replica:
host: "db2.example.com"
port: 5432
services:
- name: "auth"
url: "https://auth.example.com"
- name: "payment"
url: "https://payment.example.com"
from pcf_config import Config
config = Config("config.yaml")
# Access nested configurations
primary_db = config.get("database.primary.host")
username = config.get("database.primary.credentials.username")
# Access array elements
services = config.get("services")
auth_service = services[0]["url"] # "https://auth.example.com"
Development
Setting up development environment
# Clone the repository
git clone https://github.com/yourusername/pcf-config.git
cd pcf-config
# Install in development mode
pip install -e .[dev]
# Run tests
pytest
# Run linting
black .
flake8
mypy pcf_config
Running Tests
# Run all tests
pytest
# Run with coverage
pytest --cov=pcf_config --cov-report=html
# Run specific test file
pytest tests/test_config.py
Contributing
Contributions are welcome! Please feel free to submit a Pull Request. For major changes, please open an issue first to discuss what you would like to change.
- Fork the repository
- Create your feature branch (
git checkout -b feature/amazing-feature) - Commit your changes (
git commit -m 'Add some amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
License
This project is licensed under the MIT License - see the LICENSE file for details.
Changelog
v1.1.0
- BREAKING: Removed singleton pattern - Config now requires explicit file path
- BREAKING: Removed convenience functions
get_configandget_config_with_default - NEW: Added
set()method for modifying configuration values - NEW: Added
save()method for persisting changes to file - IMPROVED:
get()method now supports default values with...sentinel - IMPROVED:
reload()method no longer requires file path parameter - REMOVED: loguru dependency - now uses standard logging only
- REMOVED: All Chinese characters from source code
- IMPROVED: Better error handling and type hints
v1.0.0
- Initial release
- Basic configuration loading from YAML files
- Support for nested keys with dot notation
- Default value support
- Hot reload functionality
- Singleton pattern implementation
- Optional loguru integration
Support
If you encounter any issues or have questions, please open an issue on GitHub.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pcf_config-1.1.2.tar.gz.
File metadata
- Download URL: pcf_config-1.1.2.tar.gz
- Upload date:
- Size: 9.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.9.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1772eaf71a7ee2033e262c1437a381f289e5a98b387ca3295759dcb56610e1e3
|
|
| MD5 |
9ae2bf4bb355e2edc49f5c06f9898996
|
|
| BLAKE2b-256 |
2261e98f1884116266faf641f2d76e41c046f987dc6f37586e9ef3897f07f915
|
File details
Details for the file pcf_config-1.1.2-py3-none-any.whl.
File metadata
- Download URL: pcf_config-1.1.2-py3-none-any.whl
- Upload date:
- Size: 6.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.9.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ce353cc2911775a18d35d2387d5d780012c5fd260cca327c14967e6cffaa27be
|
|
| MD5 |
6bc65be93ca3088326ca4488dce26f21
|
|
| BLAKE2b-256 |
8f25c541245ab41cf14f30ac1faa72a8849c402801799f79c2bef590ec703dae
|