Skip to main content

Friendlier tracebacks in any language.

Project description

friendly-traceback logo

friendly/friendly-traceback

  • friendly_traceback: Helps understand Python traceback
  • friendly: Prettier version of the above with some additional enhancements.

This code repository is for friendly_traceback.

Unless specified otherwise, from here on, Friendly will refer to both friendly and friendly_traceback

Description

Created with Python beginners in mind, but also useful for experienced users, Friendly replaces standard tracebacks by something easier to understand, translatable into various languages. Currently, the information provided by Friendly is only available in two languages: English and French.

The additional information provided by Friendly includes why() a certain exception occurred, what() it means, exactly where() it occurred including the value of relevant variables, and more.

Example The screenshot above was taken on Windows. In some other operating systems you might need to type python3 instead of python: Friendly requires Python version 3.6 or newer.

Installation

python -m pip install friendly_traceback

Note that most users should install friendly instead of friendly_traceback,

python -m pip install friendly

This needs to be done from a terminal. In the command shown above, python refers to whatever you need to type to invoke your favourite Python interpreter. It could be python, python3, py -3.8, etc.

For some special cases, including using a specialized editor like Mu that has its own way of installing Python packages, please consult the documentation.

Documentation

The documentation is available by clicking here.

Example

The following example illustrates the information that can be provided by Friendly.

    Traceback (most recent call last):
      File "<friendly-console:5>", line 1, in <module>
        test()
      File "<friendly-console:4>", line 2, in test
        a = cost(pi)
    NameError: name 'cost' is not defined

        Did you mean `cos`?

    A `NameError` exception indicates that a variable or
    function name is not known to Python.
    Most often, this is because there is a spelling mistake.
    However, sometimes it is because the name is used
    before being defined or given a value.

    In your program, `cost` is an unknown name.
    Instead of writing `cost`, perhaps you meant one of the following:
    *   Global scope: `cos`, `cosh`, `acos`

    Execution stopped on line 1 of file `'<friendly-console:5>'`.

    -->1: test()

            test: <function test>

    Exception raised on line 2 of file `'<friendly-console:4>'`.

       1: def test():
    -->2:    a = cost(pi)
                 ^^^^

            global pi: 3.141592653589793

Projects using friendly_traceback

The following sites or projects use friendly_traceback:

Feel free to file an issue to add your site or project if it uses either friendly or friendly_traceback.

Contribute

Contribute by making suggestions for improvements, pointing out mistakes either in the documentation or in the information provided by Friendly, or finding bugs.

If you speak a language other than English or French and feel ambitious, you might want to work on translations into your own language.

License: MIT

Some of the ideas were adopted from DidYouMean-Python (aka BetterErrorMessages) by Sylvain Desodt, a project that is also using the MIT license; that particular project is no longer maintained.

Code of Conduct

We agree with the goals behind the creation of the Python Community Code of Conduct. Contributors to this project, including those filing or commenting on an issue, are expected to do the same.

Friendly users

Friendly/friendly-traceback is used by:

Feel free to contact me to add your project to this list.

JetBrains support

We graciously acknowledge the support of JetBrains which enables us to use the professional version of PyCharm for developing Friendly.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

friendly-traceback-0.5.10.tar.gz (382.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

friendly_traceback-0.5.10-py3-none-any.whl (414.1 kB view details)

Uploaded Python 3

File details

Details for the file friendly-traceback-0.5.10.tar.gz.

File metadata

  • Download URL: friendly-traceback-0.5.10.tar.gz
  • Upload date:
  • Size: 382.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.10.1

File hashes

Hashes for friendly-traceback-0.5.10.tar.gz
Algorithm Hash digest
SHA256 315f62d186bb627c154c8f171a6e8ba7726f238829df3a6568f600af2b25ff40
MD5 0c76c9e160ace5751d4ac70db7cfa161
BLAKE2b-256 d8176188c6f5b67097a82f81e967396189061c584ce36495e9c8dcfa421a5436

See more details on using hashes here.

File details

Details for the file friendly_traceback-0.5.10-py3-none-any.whl.

File metadata

  • Download URL: friendly_traceback-0.5.10-py3-none-any.whl
  • Upload date:
  • Size: 414.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.0 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.10.1

File hashes

Hashes for friendly_traceback-0.5.10-py3-none-any.whl
Algorithm Hash digest
SHA256 8e50e7e7a9737a6d10e87a4edb20f1227aa69349eb9dfeec8765b991f8376514
MD5 6a1baab0c3a3f9ec179d381b597dbc6a
BLAKE2b-256 b7df8f2e000f0cc8c9e2cbad104c34b7e4baa6c1e82436f051dad3d988376f4a

See more details on using hashes here.

Supported by

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