Skip to main content

Collectionish is a pure python library extending the basic collection data types and operations for working with them.

Project description

collectionish

Collectionish is a pure python library extending the basic collection data types and operations for working with them.


pypi version build documentation status coverage

  • Free software: MIT license
  • Documentation: docs
  • Supported Python Versions: >=3.7

Getting Started:

Install the latest stable version with pip:

$ pip install collectionish

Checkout the docs:

It's best to checkout the docs. There you'll find detailed documentation of collectionish's features and lots of examples of how to use them.

--

What's is it?

Python is a wonderful language when it comes to extending inbuilt types and making things that quack. collectionish subscribes to the ideology that the behaviour of data structures belongs in data structures and that it's better and more graceful to bake the behavior into a type than to complicate surrounding business logic creating many more wtf moments and room for bugs to sneak in.

Python's own [collections][https://docs.python.org/library/collections.html] module is a great example. take defaultdict, how many times have you seen something like this?

pets = [('cat', 'tabby'),
        ('cat', 'ginger'),
        ('dog', 'beagle'),
        ('dog', 'poodle'),
        ('lizard', 'gecko')
       ]

pet_dict = {}
for typ, subtyp in pets:
    try:
        pet_dict[typ].append(subtyp)
    except KeyError:
        # now we'll need to make an comment to explain...
        # if the key doesn't exist pet_dict we make a new
        # list containing the pet's subtype
        pet_dict[typ] = [subtyp]

vs:

from collections import defaultdict

pet_dict = defaultdict(list)
for typ, subtyp in pets:
    pet_dict[typ].append(subtyp)

collectionish adds some extra collections such like AttyDict (a straightforward recursive dot access dict ) and UniqueTuple ( a tuple of unique items that remembers insertion order). New collections will be added fairly regularly on the basis that they are generic enough and useful enough that i find myself repeating them in other projects.

In addition to data structures collectionish also provides some operations for working with data structures (from both standard python and collections) like the recursive getters and setters collectionish.ops.


Principles:

useful enough:
Inspirations for data structures should come from stuff we've written or needed before at some point.

generic enough:
To be extended within reason.

specific enough:
To be clear about what things do. We don't aim to make the data structure or stand in for a pandas dataframe that does everything.

intuitive enough:
type hinting should generally work the same as it does with parent types, signatures should not be wildly different, obvious magic methods or such as __iter__ should not generally be missing from data types.

documented enough:
All public structures and ops should be documented and have doctest examples so we know its correct and It should be fairly obvious from somethings name what it is.

tested more than enough:
we test with the excellent [hypothesis][https://github.com/HypothesisWorks/hypothesis] library wherever possible. We do doctests to keep documentation correct.

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

collectionish-0.5.0.tar.gz (14.5 kB view details)

Uploaded Source

Built Distribution

collectionish-0.5.0-py2.py3-none-any.whl (12.7 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file collectionish-0.5.0.tar.gz.

File metadata

  • Download URL: collectionish-0.5.0.tar.gz
  • Upload date:
  • Size: 14.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.25.1 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.55.0 CPython/3.8.6

File hashes

Hashes for collectionish-0.5.0.tar.gz
Algorithm Hash digest
SHA256 a710f79a0b5fb1e9b30f69afb63629b1d14bc9b2b540c2b76c3ef6e1b1349623
MD5 17d0bfc212882aabcfd1ee387c8d6e2a
BLAKE2b-256 b3d701a60d4ce7059f7c63fa5e14c887a1bd3b95cbc8b131dd549c3cf4b5e6f2

See more details on using hashes here.

File details

Details for the file collectionish-0.5.0-py2.py3-none-any.whl.

File metadata

  • Download URL: collectionish-0.5.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 12.7 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.25.1 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.55.0 CPython/3.8.6

File hashes

Hashes for collectionish-0.5.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 67838d3dc07128731a1f9360253e3a4ef2eca8afc39c5128210f25758ed10dee
MD5 624828eec37dbb92617a0035b94e3d34
BLAKE2b-256 6ba14f9b0f389272955040d8e52f7b8abda1c6fc4c4b4d2f726a8c91a76e772d

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