Dictionary with loose rules for finding keys.
Project description
PermissiveDict
Dictionary class with loose rules for returning an attribute or a requested key value.
Note: may resort to iterating the dict values to find the matching requested key, so is potentially slow.
Key is first directly found using the exact key, and then loose rules are used.
Installing
pip install permissive-dict
Key Search Rules:
- Keys compared without regard to case.
- Spaces, underscores, full-stops and dashes are equivalent in a requested key.
- Requested key is converted to str and stripped for wild card searching.
- Items in the list can be retrieved by, get, attribute_access, call or array requested_key.
- First matching element is returned.
- Default of '' is used instead of dict standard None or raising KeyError
- Multiple keys can be supplied separated with , (comma)
Example:
from permissive_dict import PermissiveDict
a = PermissiveDict({'A B': 2, 4: 4})
a.get('A_b') == a['a_b'] == a['A b'] == a['A_B'] == a['a-b '] == a['a.b '] == a.a_b == a.A_b == a('a-b')
a.get('blue,4') == 4
a.get('4') == a[4] == a(4) == a('4')
Items with multiple wildcard keys matching in the dictionary will return the first item found.
Keys can be accessed as attributes, array index, get() or by calling the instance variable.
Key and value can be set as an attribute.
Example:
a = PermissiveDict()
a.hello = 4
a.hello == a['hello'] == a('hello') == a.get('HellO')
Converting an entire list of dicts
An entire list of dictionaries can be converted to PermissiveDict using
the convert_list method. NOTE: no deep conversion is done and child
dictionaries are not converted.
Example:
list_of_dicts = [dict(a=n) for n in range(10)]
permissive_list = PermissiveDict.convert_list(list_of_dicts)
Notes
Only Python 3 is supported.
Release history
1.0.4 Fix missing handling of _ and -
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
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 permissive-dict-1.0.4.tar.gz.
File metadata
- Download URL: permissive-dict-1.0.4.tar.gz
- Upload date:
- Size: 4.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5b274b982c9dbcb058e9a665b752c9cee4bf4a4d957762ee528daad1eb009a8d
|
|
| MD5 |
6ec71fd081b4cca96263cad850fedfc0
|
|
| BLAKE2b-256 |
f8c4928bccb0e7bacc06a0f5b9216ee790f231025d2bc0ab50f034598ca33d35
|
File details
Details for the file permissive_dict-1.0.4-py2.py3-none-any.whl.
File metadata
- Download URL: permissive_dict-1.0.4-py2.py3-none-any.whl
- Upload date:
- Size: 5.1 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/4.0.1 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.4
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6a0d0330be7bf6a496310d8c07eb3bd3aa1a782b7322b1393a912e7ae364e508
|
|
| MD5 |
89858a5fe13389b16529101b5c0d176b
|
|
| BLAKE2b-256 |
213b03b0f92f754515166c74f0327fa72861ba143790baa72bc120adef60f250
|