Multi-key dictionary, supports adding and manipulating key-aliases pointing to shared values
Project description
Aldict
Multi-key dictionary, supports adding and manipulating key-aliases pointing to shared values
How to use
- initialize with aliases
(one-liner with aliases dict mapping original key to alias keys)
ad = AliasDict({"a": 1, "b": 2}, aliases={"a": ["aa", "aaa"], "b": "bb"})
assert ad["a"] == ad["aa"] == ad["aaa"] == 1
assert ad["b"] == ad["bb"] == 2
- add_alias
(pass key as first parameter and alias(es) as variadic params, list or tuple)
ad = AliasDict({"a": 1, "b": 2})
ad.add_alias("a", "aa")
ad.add_alias("b", "bb", "Bbb")
ad.add_alias("a", ["aaa", "aaaa"])
ad.add_alias("b", ("bbb",))
assert ad["a"] == ad["aa"] == ad["aaa"] == ad["aaaa"] == 1
assert ad["b"] == ad["bb"] == ad["Bbb"] == ad["bbb"] == 2
- remove_alias
(pass alias(es) to be removed as variadic params, list or tuple)
ad.remove_alias("aa")
ad.remove_alias("bb", "Bbb")
ad.remove_alias(["aaa", "aaaa"])
ad.remove_alias(("bbb",))
assert len(ad.aliases()) == 0
- clear_aliases
(remove all aliases at once)
ad.clear_aliases()
assert len(ad.aliases()) == 0
- update alias
(point alias to different key)
ad = AliasDict({"a": 1, "b": 2})
ad.add_alias("a", "ab")
assert list(ad.items()) == [('a', 1), ('b', 2), ('ab', 1)]
ad.add_alias("b", "ab")
assert list(ad.items()) == [('a', 1), ('b', 2), ('ab', 2)]
- read all aliases
ad = AliasDict({"a": 1, "b": 2})
ad.add_alias("a", "aa")
ad.add_alias("b", "bb", "B")
ad.add_alias("a", "ab", "A")
assert list(ad.aliases()) == ['aa', 'bb', 'B', 'ab', 'A']
- keys_with_aliases
(read keys with corresponding alias(es))
assert dict(ad.keys_with_aliases()) == {'a': ['aa', 'ab', 'A'], 'b': ['bb', 'B']}
- read dictviews
(dict.keys() and dict.items() include aliased versions)
ad = AliasDict({"x": 10, "y": 20})
ad.add_alias("x", "Xx")
ad.add_alias("y", "Yy", "xyz")
ad.keys()
ad.values()
ad.items()
# dict_keys(['x', 'y', 'Xx', 'Yy', 'xyz'])
# dict_values([10, 20])
# dict_items([('x', 10), ('y', 20), ('Xx', 10), ('Yy', 20), ('xyz', 20)])
- iterkeys
(lazy iterator over all keys and aliases)
ad = AliasDict({"x": 10, "y": 20})
ad.add_alias("x", "Xx")
assert list(ad.iterkeys()) == ['x', 'y', 'Xx']
- iteritems
(lazy iterator over all items including alias/value pairs)
assert list(ad.iteritems()) == [('x', 10), ('y', 20), ('Xx', 10)]
- remove key and aliases
ad.pop("y")
assert list(ad.items()) == [('x', 10), ('Xx', 10)]
- origin_len
(get original dict length without aliases)
ad = AliasDict({"a": 1, "b": 2})
ad.add_alias("a", "aa")
assert list(ad.keys()) == ["a", "b", "aa"]
assert len(ad) == 3
assert ad.origin_len() == 2
- origin_keys
(get original keys only)
assert list(ad.origin_keys()) == ['x', 'y']
- origin_key
(get original key for an alias)
ad = AliasDict({"a": 1, "b": 2})
ad.add_alias("a", "aa")
assert ad.origin_key("aa") == "a"
assert ad.origin_key("a") is None # not an alias
- is_alias
(check if key is an alias)
ad = AliasDict({"a": 1, "b": 2})
ad.add_alias("a", "aa")
assert ad.is_alias("aa") is True
assert ad.is_alias("a") is False
- has_aliases
(check if key has any aliases)
ad = AliasDict({"a": 1, "b": 2})
ad.add_alias("a", "aa")
assert ad.has_aliases("a") is True
assert ad.has_aliases("b") is False
- copy
ad = AliasDict({"a": 1, "b": 2})
ad.add_alias("a", "aa")
ad_copy = ad.copy()
assert ad_copy == ad
assert ad_copy is not ad
- merge with | and |= operators
ad1 = AliasDict({"a": 1}, aliases={"a": "aa"})
ad2 = AliasDict({"b": 2}, aliases={"b": "bb"})
merged = ad1 | ad2
assert merged["aa"] == 1
assert merged["bb"] == 2
ad1 |= {"c": 3}
assert ad1["c"] == 3
- fromkeys
ad = AliasDict.fromkeys(["a", "b", "c"], 0, aliases={"a": "aa"})
assert ad["a"] == ad["aa"] == 0
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
aldict-1.2.0.tar.gz
(5.0 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 aldict-1.2.0.tar.gz.
File metadata
- Download URL: aldict-1.2.0.tar.gz
- Upload date:
- Size: 5.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.7.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e904eeb4ed91ce44575dbacca9b3f402688f7e4457753569eb063d9d1f3cb027
|
|
| MD5 |
61c560fcfb374d6e2418e768ba59532e
|
|
| BLAKE2b-256 |
5c65a72b42f7d5593e235f97f1f2a63a4aec990ab4f0fa6b581f5cacf614bcee
|
File details
Details for the file aldict-1.2.0-py3-none-any.whl.
File metadata
- Download URL: aldict-1.2.0-py3-none-any.whl
- Upload date:
- Size: 5.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.7.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
bf5c6d20de4f96d33f11fb51e7efcc7ce311edf512c1210be0e8718ee3be761a
|
|
| MD5 |
a3f36c5a1671e2035fc1aae7db64be22
|
|
| BLAKE2b-256 |
dbdf251378ccb3a335f754d5dcce6f5aaf748479f8d483ecf53ce22ffe2b994a
|