Skip to main content

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

Project description

Build Status Coverage

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

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

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

Overview

This package includes one module - collections_extended. This module provides a bag class, AKA multiset, and a setlist class, which is a unique list or ordered set. There are also frozen (hashable) varieties of each included.

Tested against Python 2.6, 2.7, 3.2, 3.3, 3.4 & PyPy.

Getting Started

>>> from collections_extended import bag, setlist
>>> 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

Installation

pip install collections-extended

Usage

from collections_extended import bag, frozenbag, setlist, frozensetlist

Classes

There are four new classes 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.

Collection Factory

A Collection factory is provided where you can specify whether you want the Collection returned to be mutable, have unique elements and/or be ordered. If an Iterable object is passed the Collection will be filled from it, otherwise it will be empty.

collection(it = None, mutable=True, unique=False, ordered=False)

Author:

Michael Lenzen

Copyright:

2015 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-0.3.1.tar.gz (8.3 kB view details)

Uploaded Source

Built Distribution

collections_extended-0.3.1-py2.py3-none-any.whl (31.5 kB view details)

Uploaded Python 2 Python 3

File details

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

File metadata

File hashes

Hashes for collections-extended-0.3.1.tar.gz
Algorithm Hash digest
SHA256 ce0b03a5eddb286381f68fde6fd7560e43afbe4e77487270ad12e582a88a8b7e
MD5 e2d16fda00438436404ee106ea4d5838
BLAKE2b-256 a93df4c34c36f8dbf60998952cfa19b58362767e03ba925c73dc4c7ec934db7f

See more details on using hashes here.

File details

Details for the file collections_extended-0.3.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for collections_extended-0.3.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 f8ed0698e7cb6813cf15d356faafb4d75620e85fffc89e2de23beaebc90fe2e6
MD5 d7e22980deba6e796bafe423cf08b756
BLAKE2b-256 c55ee5f6637987ea92b348dcc4fdf0e37318f04ac99e04271c2da4be7117c3d3

See more details on using hashes here.

Supported by

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