Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/developerrsquared/case-insensitive-dict
Typed Python Case Insensitive Dictionary
https://github.com/developerrsquared/case-insensitive-dict
development dict pypi python python3 tooling utils
Last synced: 4 months ago
JSON representation
Typed Python Case Insensitive Dictionary
- Host: GitHub
- URL: https://github.com/developerrsquared/case-insensitive-dict
- Owner: DeveloperRSquared
- License: mit
- Created: 2022-01-30T21:22:20.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2024-04-29T17:11:14.000Z (10 months ago)
- Last Synced: 2024-04-29T18:30:52.999Z (10 months ago)
- Topics: development, dict, pypi, python, python3, tooling, utils
- Language: Python
- Homepage: https://pypi.org/project/case-insensitive-dictionary/
- Size: 187 KB
- Stars: 5
- Watchers: 1
- Forks: 1
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Case Insensitive Dict
Typed Python Case Insensitive Dictionary
[data:image/s3,"s3://crabby-images/65463/6546331ddfdbe374e269122766c345c6c1208fa5" alt="Publish"](https://github.com/DeveloperRSquared/case-insensitive-dict/actions/workflows/publish.yml)
[data:image/s3,"s3://crabby-images/f63ed/f63edaa19575b7c87069f7de3bb517022134d771" alt="Python 3.7+"](#case-insensitive-dict)
[data:image/s3,"s3://crabby-images/76876/76876a26095ad9ae31e8d798f78ef4cebf2c015a" alt="PyPI - License"](LICENSE)
[data:image/s3,"s3://crabby-images/21050/210505ebb0fd7ee1669ed2ad6a3284af868a082b" alt="PyPI - Version"](https://pypi.org/project/case-insensitive-dictionary)[data:image/s3,"s3://crabby-images/2c3ec/2c3ec5986c9156a4fa119cbe9b82f77d994d723c" alt="CodeQL"](https://github.com/DeveloperRSquared/case-insensitive-dict/actions/workflows/codeql-analysis.yml)
[data:image/s3,"s3://crabby-images/ed689/ed68977d320ad59304527d620ce6c4e77a3b53f3" alt="codecov"](https://codecov.io/gh/DeveloperRSquared/case-insensitive-dict)
[data:image/s3,"s3://crabby-images/c88de/c88de981a66d6606bdb77786e31010cf9acc724e" alt="pre-commit.ci status"](https://results.pre-commit.ci/latest/github/DeveloperRSquared/case-insensitive-dict/main)[data:image/s3,"s3://crabby-images/2b8ac/2b8ac0b40688968d026c257731b2e37213f350f1" alt="Imports: isort"](https://pycqa.github.io/isort/)
[data:image/s3,"s3://crabby-images/98647/986475842f2907062b79c4bb27fdd075d638e5b9" alt="Code style: black"](https://github.com/psf/black)
[data:image/s3,"s3://crabby-images/ae90a/ae90a1b17cdb458fe3d891a0e5eca828a68a1e69" alt="Checked with mypy"](http://mypy-lang.org/)## Install
Install and update using [pip](https://pypi.org/project/case-insensitive-dictionary/).
```sh
$ pip install -U case-insensitive-dictionary
```## API Reference
| Method | Description |
|:--------------------------|:----------------------------------------------------------------------------------------------------------------------------------------------------|
| clear() | Removes all elements from the dictionary. |
| copy() | Returns a copy of the dictionary. |
| get(key, default) | Returns the value (case-insensitively), of the item specified with the key.
Falls back to the default value if the specified key does not exist. |
| getkey(key) | Returns the original case-sensitive key using a case-insensitive search. |
| fromkeys(iterable, value) | Returns a dictionary with the specified keys and the specified value. |
| keys() | Returns the dictionary's keys. |
| values() | Returns the dictionary's values. |
| items() | Returns the key-value pairs. |
| pop(key) | Remove the specified item (case-insensitively).
The value of the removed item is the return value. |
| popitem() | Remove the last item that was inserted into the dictionary.
For Python version <3.7, popitem() removes a random item. |## Example
CaseInsensitiveDict:
```py
>>> from typing import Union>>> from case_insensitive_dict import CaseInsensitiveDict
>>> case_insensitive_dict = CaseInsensitiveDict[Union[str, int], str](data={"Aa": "b", 1: "c"})
>>> case_insensitive_dict["aa"]
'b'
>>> case_insensitive_dict[1]
'c'
>>> case_insensitive_dict.getkey("aa")
'Aa'```
which also supports json encoding/decoding:
```py
>>> import json>>> from case_insensitive_dict import CaseInsensitiveDict, CaseInsensitiveDictJSONEncoder, case_insensitive_dict_json_decoder
>>> case_insensitive_dict = CaseInsensitiveDict[str, str](data={"Aa": "b"})
>>> json_string = json.dumps(obj=case_insensitive_dict, cls=CaseInsensitiveDictJSONEncoder)
>>> json_string
'{"Aa": "b"}'>>> case_insensitive_dict = json.loads(s=json_string, object_hook=case_insensitive_dict_json_decoder)
>>> case_insensitive_dict
CaseInsensitiveDict({'Aa': 'b'})
```## Contributing
Contributions are welcome via pull requests.
### First time setup
```sh
$ git clone [email protected]:DeveloperRSquared/case-insensitive-dict.git
$ cd case-insensitive-dict
$ poetry install
$ poetry shell
```Tools including black, mypy etc. will run automatically if you install [pre-commit](https://pre-commit.com) using the instructions below
```sh
$ pre-commit install
$ pre-commit run --all-files
```### Running tests
```sh
$ poetry run pytest
```## Links
- Source Code:
- PyPI Releases:
- Issue Tracker: