Metadata-Version: 2.0
Name: braceexpand
Version: 0.1.5
Summary: Bash-style brace expansion for Python
Home-page: https://github.com/trendels/braceexpand
Author: Stanis Trendelenburg
Author-email: stanis.trendelenburg@gmail.com
License: MIT
Platform: UNKNOWN
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 2
Classifier: Programming Language :: Python :: 2.7
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Classifier: Programming Language :: Python :: 3.7

Bash-style brace expansion for Python
=====================================

|build-status-img|

Implements Brace Expansion as described in
`bash(1) <http://man7.org/linux/man-pages/man1/bash.1.html#EXPANSION>`__,
with the following limitations:

-  A pattern containing unbalanced braces will raise an
   ``UnbalancedBracesError`` exception. In bash, unbalanced braces will
   either be partly expanded or ignored.

-  A mixed-case character range like ``'{Z..a}'`` or ``'{a..Z}'`` will
   not include the characters :literal:`[]^_\`` between ``Z`` and ``a``.

``braceexpand`` is tested with Python 2.7, and 3.5+

Installation
------------

Install the ``braceexpand`` package from pypi:

::

   $ pip install braceexpand

Examples
--------

The ``braceexpand`` function returns an iterator over the expansions
generated from a pattern.

.. code:: python

   >>> from braceexpand import braceexpand

   # Integer range
   >>> list(braceexpand('item{1..3}'))
   ['item1', 'item2', 'item3']

   # Character range
   >>> list(braceexpand('{a..c}'))
   ['a', 'b', 'c']

   # Sequence
   >>> list(braceexpand('index.html{,.backup}'))
   ['index.html', 'index.html.backup']

   # Nested patterns
   >>> list(braceexpand('python{2.{5..7},3.{2,3}}'))
   ['python2.5', 'python2.6', 'python2.7', 'python3.2', 'python3.3']

   # Prefixing an integer with zero causes all numbers to be padded to
   # the same width.
   >>> list(braceexpand('{07..10}'))
   ['07', '08', '09', '10']

   # An optional increment can be specified for ranges.
   >>> list(braceexpand('{a..g..2}'))
   ['a', 'c', 'e', 'g']

   # Ranges can go in both directions.
   >>> list(braceexpand('{4..1}'))
   ['4', '3', '2', '1']

   # Numbers can be negative
   >>> list(braceexpand('{2..-1}'))
   ['2', '1', '0', '-1']

   # Unbalanced braces raise an exception.
   >>> list(braceexpand('{1{2,3}'))
   Traceback (most recent call last):
       ...
   UnbalancedBracesError: Unbalanced braces: '{1{2,3}'

   # By default, the backslash is the escape character.
   >>> list(braceexpand(r'{1\{2,3}'))
   ['1{2', '3']

   # Setting 'escape' to False disables backslash escaping.
   >>> list(braceexpand(r'\{1,2}', escape=False))
   ['\\1', '\\2']

License
-------

braceexpand is licensed unter the MIT License. See the included file
``LICENSE`` for details.

.. |build-status-img| image:: https://travis-ci.org/trendels/braceexpand.svg
   :target: https://travis-ci.org/trendels/braceexpand