Skip to main content

Democritus functions for working with Python dictionaries.

Project description

Democritus Dicts

PyPI CI Lint codecov The Democritus Project uses semver version 2.0.0 The Democritus Project uses black to format code License: LGPL v3

Democritus functions[1] for working with Python dictionaries.

[1] Democritus functions are simple, effective, modular, well-tested, and well-documented Python functions.

We use d8s (pronounced "dee-eights") as an abbreviation for democritus (you can read more about this here).

Installation

pip install d8s-dicts

Usage

You import the library like:

from d8s_dicts import *

Once imported, you can use any of the functions listed below.

Functions

  • def dict_filter_by_values(dictionary: dict, filter_function: Callable) -> dict:
        """."""
    
  • def dict_filter_by_keys(dictionary: dict, filter_function: Callable) -> dict:
        """."""
    
  • def is_dict(possible_dict: Any) -> bool:
        """Return whether or not the possible_dict is a dictionary."""
    
  • def dict_keys(dictionary: dict) -> List[Any]:
        """Get the dictionary's keys (as a list)."""
    
  • def is_valid_dict_key(key: Any) -> bool:
        """Return whether or not a dictionary could have the given key."""
    
  • def dict_values(dictionary: dict) -> List[Any]:
        """Get the dictionary's values (as a list)."""
    
  • def dict_has_value(dictionary: dict, value) -> bool:
        """Return whether or not the dictionary has the given value (without evaluating the value)."""
    
  • def dict_key_types(dictionary: dict) -> list:
        """Return a list with the type of each key in the dictionary."""
    
  • def dict_value_types(dictionary: dict) -> dict:
        """Return a dictionary with the same keys and the type of each value in place of the actual value."""
    
  • def dict_keys_with_value(dictionary: dict, value):
        """Find the key(s) in the dictionary which have the given value."""
    
  • def dict_sort_by_keys(dictionary: dict, **kwargs) -> collections.OrderedDict:
        """Sort the dictionary based on the dictionary's keys."""
    
  • def dict_sort_by_values(dictionary: dict, **kwargs) -> collections.OrderedDict:
        """Sort the dictionary based on the dictionary's values."""
    
  • def dicts_sort_by_value_at_key(dictionaries: List[Dict[Any, Any]], key, **kwargs) -> List[Dict[Any, Any]]:
        """Sort the given dictionaries (we are assuming that we get a list of dictionaries) based on each dictionary's value at the given key."""
    
  • def dict_flip(dictionary: dict, *, flatten_values: bool = False, flip_lists_and_sets: bool = False) -> dict:
        """Flip the dictionary's keys and values; all of the values become keys and keys become values."""
    
  • def dict_delistify_values(dictionary: dict) -> dict:
        """For all values in the given dictionary that are lists whose lengths are one, replace the list of length one with the value in the list."""
    
  • def dict_examples(n: int = 10, **kwargs) -> List[Dict[Any, Any]]:
        """Create n dictionary examples."""
    
  • def dict_add(dictionary: Dict[Any, List[Any]], key: Any, value: Any) -> Dict[Any, List[Any]]:
        """Add the given value to the dictionary at the given key. This function expects that all values of the dictionary parameter are lists."""
    
  • def dicts_diffs(dictionary_a: dict, dictionary_b: dict) -> list:
        """."""
    
  • def dict_copy_value_at_key(dictionary: dict, key: Any, new_key: Any) -> dict:
        """Copy the value at the given key into the new key."""
    
  • def dict_move_value_at_key(dictionary: dict, old_key: Any, new_key: Any) -> dict:
        """Move the given key and its values into the new key."""
    
  • def dict_key_delete(dictionary: dict, key: Any) -> dict:
        """Delete the given key from the given dictionary."""
    
  • def dict_delete_items(dictionary: dict, values_to_delete: List[Any] = None, keys_to_delete: List[Any] = None) -> dict:
        """Delete all items from the dictionary if the item's value is in values_to_delete or the item's key is in keys_to_delete."""
    
  • def dict_delete_empty_values(dictionary: dict) -> dict:
        """Delete all key-values pairs from the dictionary if the value is an empty strings, empty list, zero, False or None."""
    
  • def dict_keys_with_max_value(dictionary: dict) -> List[DictKeyType]:
        """."""
    
  • def dict_keys_with_min_value(dictionary: dict) -> List[DictKeyType]:
        """."""
    
  • def dict_value_with_max_key(dictionary: dict) -> Any:
        """."""
    
  • def dict_value_with_min_key(dictionary: dict) -> Any:
        """."""
    

Development

👋  If you want to get involved in this project, we have some short, helpful guides below:

If you have any questions or there is anything we did not cover, please raise an issue and we'll be happy to help.

Credits

This package was created with Cookiecutter and Floyd Hightower's Python project template.

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

d8s_dicts-0.6.0.tar.gz (29.2 kB view details)

Uploaded Source

Built Distribution

d8s_dicts-0.6.0-py2.py3-none-any.whl (24.6 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file d8s_dicts-0.6.0.tar.gz.

File metadata

  • Download URL: d8s_dicts-0.6.0.tar.gz
  • Upload date:
  • Size: 29.2 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.5

File hashes

Hashes for d8s_dicts-0.6.0.tar.gz
Algorithm Hash digest
SHA256 7d70da66350a4d24451c74b062c2017743b34c06df6ef50050dab7d64b6a46c6
MD5 1f88d56638a594863841784b5b9ca446
BLAKE2b-256 94ab0ca7a968f18fc3ef3aef7ff6d09367470483c185599e9b31b1fbf5ffde1a

See more details on using hashes here.

File details

Details for the file d8s_dicts-0.6.0-py2.py3-none-any.whl.

File metadata

  • Download URL: d8s_dicts-0.6.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 24.6 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.5

File hashes

Hashes for d8s_dicts-0.6.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 54906ef88b5a2bc145a30f4317e8eca8b5b3182ec449562be83a347311c9572a
MD5 3c9649ef3d8d6b2c0f5daa8b02f550aa
BLAKE2b-256 4460c02a1419fb4d2545522649532aad79d79c61487e9a650044b91505ad76e1

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page