Skip to main content

arbol -- Arborescent Printouts in Python

Project description

arbol | Arborescent Printouts in Python

Do you have a script, a command line tool, or some workflow in Python that has lots of 'print' statements, and you can't make sense of it once it adds up to hundreds of lines on the console? Sounds familiar?
arbol organises your stdout prints in a hierarchy that follows the structure of your code. Use a simple context manager to define the hierarchy and the 'aprint' command instead of print, and voila. Moreover, arbol measures the elpased time for each node of the tree and displays that conveniently. Finally, when the optional dependencies are installed, the printed tree and text are colored with an exquisitely crafted combination of colors, making it even more visually appealing.

If you are wondering, 'arbol' means 'tree' in spanish.

Why not use a more traditional Python logging? We have made the choice of sticking to a plain and simple scheme that matches the usage of 'print' statements. Also we could have tried to intercept stdout and do some magic there, but we prefer to keep things simple and lean, and let you choose to use arbol where it makes sense.

Installation

Install with pip:

pip install arbol

Optional dependencies

If you want colors, install the ansicolors package:

pip install ansicolors

To make sure that you get the colors on all operating systems (particularly Windows), install the colorama package:

pip install colorama

Note: both colorama and ansicolors are optional -- arbol will work fine without it installed.

Example

Here is a simple and self-explanatory example:

from arbol import Arbol, aprint, section, asection, acapture

import arbol

# for colors, install the ansicolors package: 'pip install ansicolors',
# and for windows install the colorama package: 'pip install colorama'

# You can limit the tree depth:
Arbol.max_depth = 4

# use aprint (=arbol print) instead of the standard print
aprint('Test')

# You can decorate functions:
@section('function')
def fun(x):
    if x >= 0:
        with asection('recursive call to f'):
            aprint(f"f(x)+1={fun(x - 1)}")

# The context manager let's you go down one level in the tree
with asection('a section'):
    aprint('a line')
    aprint('another line')
    aprint('we are done \n or are we? \n someone gotta check!')

    with asection('a subsection'):
        aprint('another line')
        aprint('we are done')

    # works through function calls and the like...
    fun(2)

    # You can capture stdout if you want, usefull when a 3rd party library has printouts that you want to capture...
    with acapture():
        print("No escape is possible")
        aprint("Even this works...\n")

    # You can deactivate the elapsed time measurement and printing:
    Arbol.elapsed_time = False
    fun(100)

aprint('demo is finished...')

# You can also turn off all output with one switch:
Arbol.enable_output = False
aprint('you will not see that')

And this is how it looks like:

example

Roadmap

Some ideas we might consider from serious to highly speculative:

  • More color styles to choose from
  • Intercept stdout from C code so that printouts from libraries called from python are formatted too, unclear is that's possible.
  • Generate tree automatically by inspecting stack?
  • Interoperability with logging package?

Contributions

Pull requests highly welcome!

Authors

Loic A. Royer (@loicaroyer) Ahmet Can Solak (@_ahmetcansolak)

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

arbol-2020.11.6.tar.gz (7.1 kB view details)

Uploaded Source

Built Distribution

arbol-2020.11.6-py3-none-any.whl (8.0 kB view details)

Uploaded Python 3

File details

Details for the file arbol-2020.11.6.tar.gz.

File metadata

  • Download URL: arbol-2020.11.6.tar.gz
  • Upload date:
  • Size: 7.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.25.0 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.54.0 CPython/3.8.5

File hashes

Hashes for arbol-2020.11.6.tar.gz
Algorithm Hash digest
SHA256 cae8c52f727a06412f112be6fa0e381490f82870d72723b4a8cd790c60a081bc
MD5 2b3f13ad817be6626d0e316afed28f0f
BLAKE2b-256 eff2c41c141e66fe9a27c80c41467c560c974686237adaa3d24381c846e7d236

See more details on using hashes here.

File details

Details for the file arbol-2020.11.6-py3-none-any.whl.

File metadata

  • Download URL: arbol-2020.11.6-py3-none-any.whl
  • Upload date:
  • Size: 8.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.25.0 setuptools/50.3.2 requests-toolbelt/0.9.1 tqdm/4.54.0 CPython/3.8.5

File hashes

Hashes for arbol-2020.11.6-py3-none-any.whl
Algorithm Hash digest
SHA256 1abab71a52bcf78d9b68984e91c414df0adda800cc48790243028e5ed689fcf1
MD5 f563d28a928109ae5dcd422de350aec9
BLAKE2b-256 401f151910841368b7396e91c58e06f93cf426956503485491c7de144c4e1627

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