🔩 Like builtins, but boltons. 250+ constructs, recipes, and snippets which extend (and rely on nothing but) the Python standard library. Nothing like Michael Bolton.
Go to file
Mahmoud Hashemi d50a175c69 bit of changelog formatting consistency 2020-06-21 23:00:24 -07:00
boltons Merge branch 'master' of github.com:mahmoud/boltons 2020-06-21 22:27:36 -07:00
docs bump docs version to 20.2.0 2020-06-21 22:39:25 -07:00
misc Fix warnings regarding invalid escape sequences 2020-02-01 00:22:52 +05:30
tests #122 - Adding lstrip, rstrip, and strip for iterables (#253) 2020-06-21 22:19:35 -07:00
.gitignore Remove six dependenct in ioutils 2016-10-21 16:35:22 -05:00
.travis.yml Fix travis py26 and pypy (#226) 2019-10-19 14:41:52 -07:00
CHANGELOG.md bit of changelog formatting consistency 2020-06-21 23:00:24 -07:00
LICENSE adding license 2013-03-22 21:50:02 -07:00
MANIFEST.in Create MANIFEST.in 2018-07-01 16:41:06 -07:00
README.md some python version housekeeping 2019-02-11 00:02:17 -08:00
TODO.rst add quick error report for wrap 2019-05-02 09:45:30 -07:00
appveyor.yml make appveyor install a newer tox/wheel 2019-07-01 23:23:53 -07:00
pytest.ini docstring/test for OneToOne.unique alternate constructor 2019-06-11 23:59:46 -07:00
requirements-rtd.txt a bunch of docs cleanups 2015-09-24 11:51:21 -07:00
requirements-test.txt modernize test requirements somewhat. py26 is on its last legs 2018-08-28 16:03:08 -07:00
setup.cfg Include LICENSE file in wheels 2018-07-01 16:41:06 -07:00
setup.py bump version for 20.2.1dev 2020-06-21 22:59:12 -07:00
tox.ini readd 2.6 to the tox 2018-10-10 23:46:24 -07:00

README.md

Boltons

boltons should be builtins.

Boltons is a set of over 230 BSD-licensed, pure-Python utilities in the same spirit as — and yet conspicuously missing from — the standard library, including:

Full and extensive docs are available on Read The Docs. See what's new by checking the CHANGELOG.

Boltons is tested against Python 2.6, 2.7, 3.4, 3.5, 3.6, and 3.7, as well as CPython nightly and PyPy/PyPy3.

Installation

Boltons can be added to a project in a few ways. There's the obvious one:

pip install boltons

Then, thanks to PyPI, dozens of boltons are just an import away:

from boltons.cacheutils import LRU
my_cache = LRU()

However, due to the nature of utilities, application developers might want to consider other options, including vendorization of individual modules into a project. Boltons is pure-Python and has no dependencies. If the whole project is too big, each module is independent, and can be copied directly into a project. See the Integration section of the docs for more details.

Third-party packages

The majority of boltons strive to be "good enough" for a wide range of basic uses, leaving advanced use cases to Python's myriad specialized 3rd-party libraries. In many cases the respective boltons module will describe 3rd-party alternatives worth investigating when use cases outgrow boltons. If you've found a natural "next-step" library worth mentioning, see the next section!

Gaps

Found something missing in the standard library that should be in boltons? Found something missing in boltons? First, take a moment to read the very brief architecture statement to make sure the functionality would be a good fit.

Then, if you are very motivated, submit a Pull Request. Otherwise, submit a short feature request on the Issues page, and we will figure something out.