A file based database using yaml as file format
Project description
YamlDB
YamlDB is a lightweight, easy-to-use file-based database that uses YAML as its storage format. It allows you to treat a YAML file as a dictionary in your Python application, providing a balance between the simplicity of a flat file and the functionality of a database.
Key Features
- Human Readable: Data is stored in standard YAML, making it easy to inspect and edit manually.
- Dot Notation: Access and set nested values using dot-separated keys (e.g.,
db["user.profile.name"]). - Powerful Querying: Integrated with JMESPath for complex searching and filtering.
- Data Integrity:
- Atomic Writes: Uses temporary files to ensure that crashes during saving don't corrupt your database.
- Transactions: Supports atomic transactions via a context manager; changes are rolled back if an error occurs.
- Concurrency Control: Implements file-based locking to prevent data corruption when multiple processes access the same file.
- Flexible Backends: Supports both persistent file storage (
:file:) and volatile in-memory storage (:memory:).
Installation
pip install yamldb
Note: Requires Python 3.8 or newer.
Quick Start
Basic CRUD Operations
from yamldb import YamlDB
# Initialize the database
db = YamlDB(filename="data.yml")
# Set values (creates parents automatically)
db["user.name"] = "Gregor"
db["user.age"] = 30
db["settings.theme"] = "dark"
# Get values with an optional default
name = db.get("user.name") # "Gregor"
city = db.get("user.city", default="Unknown") # "Unknown"
# Delete a key
db.delete("settings.theme")
# Save changes to disk
db.save()
Advanced Searching with JMESPath
YamlDB uses JMESPath for querying, allowing you to filter and transform your data.
# Sample data: {"users": [{"name": "Gregor", "age": 30}, {"name": "Alice", "age": 25}]}
db["users"] = [{"name": "Gregor", "age": 30}, {"name": "Alice", "age": 25}]
# Find users older than 28
results = db.search("[?age > `28`]")
# [{'name': 'Gregor', 'age': 30}]
# Get only the names of all users
names = db.search("users[].name")
# ['Gregor', 'Alice']
Transactions
Use the transaction() context manager to ensure a group of updates are applied atomically.
try:
with db.transaction():
db["account.balance"] = 100
db["account.status"] = "active"
# If an exception occurs here, both changes are rolled back
raise RuntimeError("Something went wrong!")
except RuntimeError:
print("Transaction rolled back!")
# Balance remains unchanged if it was previously different
Concurrency and Locking
YamlDB automatically handles file locking to prevent concurrent processes from corrupting the data. If a lock is held by another process, YamlDB will wait for a timeout period before raising a RuntimeError.
API Reference
YamlDB(filename="yamldb.yml", backend=":file:", data=None)
filename: Path to the YAML file.backend: Either":file:"(default) or":memory:".data: Optional initial dictionary to populate the DB.
Core Methods
get(key, default=None): Retrieves a value using dot notation.set(key, value): Sets a value using dot notation. Also supportsdb[key] = value.delete(key): Removes a key using dot notation.save(filename=None): Atomically writes the current state to disk.load(filename=None): Reloads the data from the file.search(query): Executes a JMESPath query against the data.transaction(): Context manager for atomic updates.keys(): Returns a list of all keys in the database.clear(): Removes all data from the database.dict(): Returns the internal data as a standard Python dictionary.yaml(): Returns the data as a YAML string.
Development and Tests
The best way to contribute is with issues and pull requests.
git clone https://github.com/cloudmesh/yamldb.git
cd yamldb
pip install -r requirements.txt
pip install -r requirements-dev.txt
pip install -e .
Run tests with:
pytest -v tests/
Alternatives
- jmespath: The query language used by YamlDB.
- TinyDB: Another lightweight document database.
- nosqlite: A NoSQL wrapper for SQLite.
- MongoDB: A full-featured document database (YamlDB is a simpler alternative for small-scale needs).
Contributors
Special thanks to all the contributors who have helped improve YamlDB. You can see the full list of contributors on GitHub.
Acknowledgments
Continued work was in part funded by the NSF CyberTraining: CIC: CyberTraining for Students and Technologies from Generation Z with the award numbers 1829704 and 2200409.
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 yamldb-1.0.13.tar.gz.
File metadata
- Download URL: yamldb-1.0.13.tar.gz
- Upload date:
- Size: 17.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
79c4b8f437093e3a96740aa883ccf27fd003bca1b7b860de0a5d38cc338d51c1
|
|
| MD5 |
41172a6df82953f8900da304f2140f15
|
|
| BLAKE2b-256 |
d569ccb54fadd52075da45ca074d1228e6b8c047d6b8258f40b420dd925bd120
|
File details
Details for the file yamldb-1.0.13-py2.py3-none-any.whl.
File metadata
- Download URL: yamldb-1.0.13-py2.py3-none-any.whl
- Upload date:
- Size: 9.9 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fad1f9378ea41a310320a90f6e89bc87e7927690cb387d97a90a92cd63b361eb
|
|
| MD5 |
37637e94987f16ff08ef7c087e3fe7a9
|
|
| BLAKE2b-256 |
6fec5e4d379d351152f40b9479c44cf0a46d2acd75d9cecc1558748d938d976a
|