Safely access nested dictionary keys without exceptions
Project description
philiprehberger-safeget
Safely access nested dictionary keys without exceptions.
Installation
pip install philiprehberger-safeget
Usage
from philiprehberger_safeget import safeget, safeset, has_path, pluck
data = {"user": {"address": {"city": "NYC"}}}
safeget(data, "user.address.city") # "NYC"
safeget(data, "user.address.zip") # None
safeget(data, "user.address.zip", default="?") # "?"
# List index support
data = {"users": [{"name": "Alice"}, {"name": "Bob"}]}
safeget(data, "users.0.name") # "Alice"
# Check existence
has_path(data, "users.0.name") # True
has_path(data, "users.5.name") # False
# Set nested values (creates intermediates)
safeset(data, "config.debug", True)
# Extract multiple paths
pluck(data, "users.0.name", "config.debug")
# {"users.0.name": "Alice", "config.debug": True}
Deleting and walking
from philiprehberger_safeget import delete_path, walk
# Remove a nested key (mutates in place); returns True if something was removed
data = {"a": {"b": 1, "c": 2}}
delete_path(data, "a.b") # True -> data == {"a": {"c": 2}}
delete_path(data, "x.y") # False -> data unchanged
# Works on list indices too
data = {"users": [{"id": 1}, {"id": 2}]}
delete_path(data, "users.0") # True -> data == {"users": [{"id": 2}]}
# Iterate every (path, value) pair in a nested structure
for path, value in walk({"a": {"b": 1, "c": [10, 20]}}):
print(path, value)
# a {'b': 1, 'c': [10, 20]}
# a.b 1
# a.c [10, 20]
# a.c.0 10
# a.c.1 20
# Only the leaves
list(walk({"a": {"b": 1, "c": [10, 20]}}, leaves_only=True))
# [("a.b", 1), ("a.c.0", 10), ("a.c.1", 20)]
API
safeget(data, path, default=None, separator=".")— Get nested valuesafeset(data, path, value, separator=".")— Set nested valuehas_path(data, path, separator=".")— Check if path existspluck(data, *paths, default=None)— Extract multiple pathsdelete_path(data, path, separator=".")— Remove value at path; returns whether anything was removedwalk(data, leaves_only=False, separator=".")— Iterate(path, value)pairs for every node (or only leaves)
Development
pip install -e .
python -m pytest tests/ -v
Support
If you find this project useful:
License
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
philiprehberger_safeget-0.3.0.tar.gz
(185.6 kB
view details)
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 philiprehberger_safeget-0.3.0.tar.gz.
File metadata
- Download URL: philiprehberger_safeget-0.3.0.tar.gz
- Upload date:
- Size: 185.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7f6265c418b440f134c318d46aab9aec283cdc3f4e052dd51d01e4a39c521527
|
|
| MD5 |
68658ace73011a5a9b9a2cb02bcad47d
|
|
| BLAKE2b-256 |
e10eb72a271c2597af838455eaa2f8e92c66c165fe44f088262d1a40a096a23e
|
File details
Details for the file philiprehberger_safeget-0.3.0-py3-none-any.whl.
File metadata
- Download URL: philiprehberger_safeget-0.3.0-py3-none-any.whl
- Upload date:
- Size: 5.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9b8c2fe033c0a3a0589e0f6f8e730d8679d020b0b25ccc6510d75607b3f6ee0f
|
|
| MD5 |
fc1017bf17b19ec0d2d8e03474254726
|
|
| BLAKE2b-256 |
a5f1ea3ce63db69de9f39bacc4554615ddf1ba1baafe7a717e2edd5688bfb07b
|