Skip to main content

Extra Python Collections - bags (multisets) and setlists (ordered sets)

Project description

Coverage Downloads
Documentation:

http://collections-extended.lenzm.net/

GitHub:

https://github.com/mlenzen/collections-extended

PyPI:

https://pypi.python.org/pypi/collections-extended

Overview

collections_extended is a pure Python module with no dependencies providing:

  • a bag class, AKA multiset,

  • a setlist class, which is a unique list or ordered set,

  • a bijection class, RangeMap which is a mapping from ranges to values and

  • a IndexedDict class, which is an ordered mapping whose elements can be accessed using index, in addition to key.

There are also frozen (hashable) varieties of bags and setlists.

Compatible with and tested against Python 3.6, 3.7, 3.8, 3.9, 3.10 & PyPy3.

Getting Started

>>> from collections_extended import bag, setlist, bijection, RangeMap, IndexedDict
>>> from datetime import date
>>> b = bag('abracadabra')
>>> b.count('a')
5
>>> b.remove('a')
>>> b.count('a')
4
>>> 'a' in b
True
>>> b.count('d')
1
>>> b.remove('d')
>>> b.count('d')
0
>>> 'd' in b
False

>>> sl = setlist('abracadabra')
>>> sl
setlist(('a', 'b', 'r', 'c', 'd'))
>>> sl[3]
'c'
>>> sl[-1]
'd'
>>> 'r' in sl  # testing for inclusion is fast
True
>>> sl.index('d')  # so is finding the index of an element
4
>>> sl.insert(1, 'd')  # inserting an element already in raises a ValueError
Traceback (most recent call last):
...
        raise ValueError
ValueError
>>> sl.index('d')
4

>>> bij = bijection({'a': 1, 'b': 2, 'c': 3})
>>> bij.inverse[2]
'b'
>>> bij['a'] = 2
>>> bij == bijection({'a': 2, 'c': 3})
True
>>> bij.inverse[1] = 'a'
>>> bij == bijection({'a': 1, 'c': 3})
True

>>> version = RangeMap()
>>> version[date(2017, 10, 20): date(2017, 10, 27)] = '0.10.1'
>>> version[date(2017, 10, 27): date(2018, 2, 14)] = '1.0.0'
>>> version[date(2018, 2, 14):] = '1.0.1'
>>> version[date(2017, 10, 24)]
'0.10.1'
>>> version[date(2018, 7, 1)]
'1.0.1'
>>> version[date(2018, 6, 30):] = '1.0.2'
>>> version[date(2018, 7, 1)]
'1.0.2'

>>> idict = IndexedDict()
>>> idict['a'] = "A"
>>> idict['b'] = "B"
>>> idict['c'] = "C"
>>> idict.get(key='a')
'A'
>>> idict.get(index=2)
'C'
>>> idict.index('b')
1

Installation

pip install collections-extended

Usage

from collections_extended import bag, frozenbag, setlist, frozensetlist, bijection

Classes

There are seven new collections provided:

Bags

bag

This is a bag AKA multiset.

frozenbag

This is a frozen (hashable) version of a bag.

Setlists

setlist

An ordered set or a list of unique elements depending on how you look at it.

frozensetlist

This is a frozen (hashable) version of a setlist.

Mappings

bijection

A one-to-one mapping.

RangeMap

A mapping from ranges (of numbers/dates/etc)

IndexedDict

A mapping that keeps insertion order and allows access by index.

Python 2

The package no longer supports Python 2. The last version to support Python 2.7, 3.4 & 3.5 was 1.0. No new feature releases will be done for 1.x but any significant bugs that come up may be fixed.

Author:

Michael Lenzen

Copyright:

2021 Michael Lenzen

License:

Apache License, Version 2.0

Project Homepage:

https://github.com/mlenzen/collections-extended

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

collections-extended-2.0.2.tar.gz (22.8 kB view details)

Uploaded Source

Built Distribution

collections_extended-2.0.2-py3-none-any.whl (24.3 kB view details)

Uploaded Python 3

File details

Details for the file collections-extended-2.0.2.tar.gz.

File metadata

  • Download URL: collections-extended-2.0.2.tar.gz
  • Upload date:
  • Size: 22.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.4 CPython/3.10.1 Linux/5.4.151-16908-gff376e5d5ee1

File hashes

Hashes for collections-extended-2.0.2.tar.gz
Algorithm Hash digest
SHA256 d68ebd1e2208444e392aa0016e5c085bd897f89296f5c1860787de5935994114
MD5 e3d30b77666b226bcfb77bb5e21046c8
BLAKE2b-256 6240e92bd575a99b7fb1fe9f3198ff4addc7d9f66e3d7e976b4d1b5bca6e049d

See more details on using hashes here.

File details

Details for the file collections_extended-2.0.2-py3-none-any.whl.

File metadata

  • Download URL: collections_extended-2.0.2-py3-none-any.whl
  • Upload date:
  • Size: 24.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.4 CPython/3.10.1 Linux/5.4.151-16908-gff376e5d5ee1

File hashes

Hashes for collections_extended-2.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 bc096dda430b9455f51287943f7f63fbe53a4de78c444cc38c44e996af306ac5
MD5 ed0d4bc74e7b94c563813b7e3feb73dd
BLAKE2b-256 d5658f409bbb1faf21714ebebfa553a34023a6657bbb2f85f43141be4e4ffe5e

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