Skip to main content

A dual vector foil (二向箔) that squashes any Python objects into your console.

Project description

dual_vector_foil

Build Status PyPI version

A dual vector foil(二向箔) that squashes any Python objects into your console

Introduction

Simply speaking, dvf (dual vector foil) is a recursive pretty printer for any objects in Python. It allows you to inspect Python object in a simple and comprehensive way. Checkout the following example:

simple2

Example on Flask app

Flask app is very complex Python object, and dvf can use paging (less) to wrap the output. If the GIF doesn't show immediately, be patient, it's about 10 MB large (click to zoom in):

complex4

If your eyes are sharp enough, you'll find a warning at the end of the gif. That's because dvf tries to access some attributes of Flask that are only valid in a request context. The warning is quite common for complex objects.

Installation

pip install dvf

The project is still under development, so any report on bugs is highly appreciated. The development is under Python 3.7 and Python 3.6 is also tested. The package provides no Python <= 3.5 support.

Philosophy

Why not dir or __dict__

There is already an amazing inspection package pdir, which emphasize on the usage of modules and objects, while dvf is aiming at data and internal structure of objects. As a result, dvf will by default omit any object attributes that have type of function, module or class, and will try its best to expand any iterable to see what really lies in .

Safety concern

As you might have gaused, it's not wise to use dvf on untrusted object because dvf will have to evoke some methods of the object to evaluate attributes. Is this a foundamental flaw of dvf? I think not. Because if an object is really malicious, it can delete your system when it's imported, why wait untill dvf to check it?

Deal with loops

The biggest problem of dvf is loops in objects. The following class has a pointer points to himself. A simple recursion implementation of dvf will result in an infinite loop.

class Foo:

    def __init__(self):
        self.another_me = self

To solve this economically, dvf records every object it has visited and omit them next time it meet the object. That's why sometimes a complete view of certain objects is not possible.

Another troublesome case is object creation during attribute access. A typical example is NumPy array, which has an attribute of T that returns the transpose of the array, which has another T that returns another new array. So there is also an infinite loop. To solve this dvf should be very cautious toward data descriptors. Some result gained from descriptors will not be expanded.

Todo list

  • User-custom searching and filtering
  • Docs on output format
  • Tests
  • Use prompt_toolkit to build an application that can handle wide output (horizontally scollable)

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

dvf-0.1.2.tar.gz (7.9 kB view details)

Uploaded Source

Built Distribution

dvf-0.1.2-py3-none-any.whl (9.6 kB view details)

Uploaded Python 3

File details

Details for the file dvf-0.1.2.tar.gz.

File metadata

  • Download URL: dvf-0.1.2.tar.gz
  • Upload date:
  • Size: 7.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.20.0 setuptools/40.4.3 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.7.1

File hashes

Hashes for dvf-0.1.2.tar.gz
Algorithm Hash digest
SHA256 8123f66e09195c822e404392388fbe62fe3fa902f819417d6832cd937ad6a738
MD5 d4491e99ec26ba9ced26914b8ac983bc
BLAKE2b-256 385d4135e30662d5efcf270ce7d419d9a1fba4bb22163a23cc4bd5ba4deae321

See more details on using hashes here.

File details

Details for the file dvf-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: dvf-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 9.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.20.0 setuptools/40.4.3 requests-toolbelt/0.8.0 tqdm/4.28.1 CPython/3.7.1

File hashes

Hashes for dvf-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 3cd4437c38d0e5057e900688eaa064ac5f38403bf9f35075ffcdfc7b45946dad
MD5 913f2a89c88ae2046689b62e95050cf6
BLAKE2b-256 494ee1db09d064e98c7e81cc80748aa735df9de504a33a7c8ebaac23afe243c9

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