Project: braceexpand

Bash-style brace expansion for Python

Project Details

Latest version
0.1.7
Home Page
https://github.com/trendels/braceexpand
PyPI Page
https://pypi.org/project/braceexpand/

Project Popularity

PageRank
0.0017884073721598172
Number of downloads
454713

Bash-style brace expansion for Python

|build-status-img| |PyPI|

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.6+

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 under 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 .. |PyPI| image:: https://img.shields.io/pypi/v/braceexpand :target: https://pypi.python.org/pypi/braceexpand