Skip to main content

Python Fancy Printer

Project description

nicely

Python Fancy Printer

Abstract

The nicely package is yet another 'pretty printer'.

It is meant to:

  • have a readable and consistent output.

    • Nested levels are indented. (the indentation string is configurable (4 spaces by default))
    • The sequences and the mapping keys are sorted. (can be disabled)
    • Mapping keys are padded. (so the values are aligned)
    • The data types may be shown. (disabled by default)
  • be simple to use.

    • Only one class is required.
    • Convinience functions are also provided.
  • be extensible

    • If the provided support for standard types doesn't suit your need, it's easy to modify it.
    • Any object can easaly be supported.
  • be able to handle large data structure.

    • Sequences, mappings, strings and multi-lines can be truncated as needed.
    • Mapping items can be omitted based on regex.

Usage

There are several ways to use nicel.

The Printer class:

from nicely import Printer

p = Printer()
p.print(some_data_structure)

The Printer.print method sends a formatted representation of its argument to a file-like destination (stdout by default).

The dump function:

from nicely import dump

dump(some_data_structure)

The dump function uses the Printer class to 'dump' its argument on stdout as well as to a file ('nicely.dump' by default).

The format function:

from nicely import format

string = format(some_data_structure)

The format function uses the Printer class to get a string representation of an object.

Data Types support

There are 2 ways for an object to be "printable" / "dumpable":

The Formatter class

The Printer class needs one Formatter for each supported data type (exept for string).

A set of default Formatter is provided by the formatters module for Python's builtin types and should be good enough for most purposes.

These formatters can be modified or extended at will to support new types or modify the output for existing ones.

The print method

Any object can become 'printable' by implementing the print method which will call the Printer's methods in appropriate ways.

Installation

$ pip install nicely

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

nicely-0.2542.0.tar.gz (10.9 kB view details)

Uploaded Source

Built Distribution

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

nicely-0.2542.0-py3-none-any.whl (9.2 kB view details)

Uploaded Python 3

File details

Details for the file nicely-0.2542.0.tar.gz.

File metadata

  • Download URL: nicely-0.2542.0.tar.gz
  • Upload date:
  • Size: 10.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for nicely-0.2542.0.tar.gz
Algorithm Hash digest
SHA256 80b9fe12ec24380767c6988e756920dd5e71e72825da4d8c760ba12395948973
MD5 5e14c3498bf24835c4d99b08e80746d1
BLAKE2b-256 20b9e6e533d04bc7cdd138985b0fbbbbd6c26a6960b5ae57118e9bb47799baa7

See more details on using hashes here.

File details

Details for the file nicely-0.2542.0-py3-none-any.whl.

File metadata

  • Download URL: nicely-0.2542.0-py3-none-any.whl
  • Upload date:
  • Size: 9.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.7

File hashes

Hashes for nicely-0.2542.0-py3-none-any.whl
Algorithm Hash digest
SHA256 e1b489bb9ae4ecba45ee225ad9b88cfd4b6fa9b8b01774281c063c9a51461268
MD5 cf1c3dce845bef074ab652667c2d28f0
BLAKE2b-256 19c5078c1ea401cbfcf09b76708579a7d2abda7df45fbd2cfa4b6b618defa1c1

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