Skip to main content

A simple program and library to auto generate API documentation for Python modules.

Project description

pdocs - Documentation Powered by Your Python Code.


PyPI version Build Status codecov Join the chat at https://gitter.im/pdocs/community License Downloads


Read Latest Documentation - Browse GitHub Code Repository


pdocs is a library and a command line program to discover the public interface of a Python module or package. The pdocs script can be used to generate Markdown or HTML of a module's public interface, or it can be used to run an HTTP server that serves generated HTML for installed modules.

pdocs is an MIT Licensed fork of pdoc's original implementation by Andrew Gallant (@BurntSushi). with the goal of staying true to the original vision layed out by the project's creator.

NOTE: For most projects, the best way to use pdocs is using portray.

asciicast

Features

  • Support for documenting data representation by traversing the abstract syntax to find docstrings for module, class and instance variables.
  • For cases where docstrings aren't appropriate (like a namedtuple), the special variable __pdocs__ can be used in your module to document any identifier in your public interface.
  • Usage is simple. Just write your documentation as Markdown. There are no added special syntax rules.
  • pdocs respects your __all__ variable when present.
  • pdocs will automatically link identifiers in your docstrings to its corresponding documentation.
  • When pdocs is run as an HTTP server, external linking is supported between packages.
  • The pdocs HTTP server will cache generated documentation and automatically regenerate it if the source code has been updated.
  • When available, source code for modules, functions and classes can be viewed in the HTML documentation.
  • Inheritance is used when possible to infer docstrings for class members.

The above features are explained in more detail in pdocs's documentation.

pdocs is compatible with Python 3.6 and newer.

Quick Start

The following guides should get you up using pdocs in no time:

  1. Installation - TL;DR: Run pip3 install pdocs within your projects virtual environment.
  2. Command Line Usage - TL;DR: Run pdocs server YOUR_MODULES to test and pdocs as_html YOUR_MODULES to generate HTML.
  3. API Usage - TL;DR: Everything available via the CLI is also easily available programmatically from within Python.

Differences Between pdocs and pdoc

Below is a running list of intentional differences between pdoc and pdocs:

  • pdocs has built-in support for Markdown documentation generation (as needed by portray).
  • pdocs has built-in support for the inclusion of Type Annotation information in reference documentation.
  • pdocs requires Python 3.6+; pdoc maintains Python2 compatibility as of the latest public release.
  • pdocs uses the most recent development tools to ensure long-term maintainability (mypy, black, isort, flake8, bandit, ...)
  • pdocs generates project documentation to a temporary folder when serving locally, instead of including a live server. An intentional trade-off between simplicity and performance.
  • pdocs provides a simplified Python API in addition to CLI API.
  • pdocs is actively maintained.
  • pdocs uses hug CLI and sub-commands, pdoc uses argparse and a single command.
  • pdoc provides textual documentation from the command-line, pdocs removed this feature for API simplicity.

Notes on Licensing and Fork

The original pdoc followed the Unlicense license, and as such so does the initial commit to this fork here. Unlicense is fully compatible with MIT, and the reason for the switch going forward is because MIT is a more standard and well-known license.

As seen by that commit, I chose to fork with fresh history, as the project is very old (2013) and I felt many of the commits that happened in the past might, instead of helping to debug issues, lead to red herrings due to the many changes that have happened in the Python eco-system since that time. If you desire to see the complete history for any reason, it remains available on the original pdoc repository.

Why Create pdocs?

I created pdocs to help power portray while staying true to the original vision of pdoc and maintain MIT license compatibility. In the end I created it to help power better documentation websites for Python projects.

I hope you, too, find pdocs useful!

~Timothy Crosley

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

tmp_fat_pdocs-1.2.0.tar.gz (420.6 kB view details)

Uploaded Source

Built Distribution

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

tmp_fat_pdocs-1.2.0-py3-none-any.whl (35.5 kB view details)

Uploaded Python 3

File details

Details for the file tmp_fat_pdocs-1.2.0.tar.gz.

File metadata

  • Download URL: tmp_fat_pdocs-1.2.0.tar.gz
  • Upload date:
  • Size: 420.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.12.7

File hashes

Hashes for tmp_fat_pdocs-1.2.0.tar.gz
Algorithm Hash digest
SHA256 c42d82c2c5df2cf0ac9d61ec4c49f16f7ef1b132e989b65410c3bc9102605c5a
MD5 61ba5431c2e6e46d08d2f75a3292d488
BLAKE2b-256 2d7c688fc2405dc47a69d65e39f4e492cbce171da039c56acca0372b2ccb27ff

See more details on using hashes here.

File details

Details for the file tmp_fat_pdocs-1.2.0-py3-none-any.whl.

File metadata

  • Download URL: tmp_fat_pdocs-1.2.0-py3-none-any.whl
  • Upload date:
  • Size: 35.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.12.7

File hashes

Hashes for tmp_fat_pdocs-1.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 573f98e6953490609994ca1da8776f6a847ce42aa7ac05d01cff5a3c2f8761e1
MD5 71848b36c36cb33fa861f50b7e00067f
BLAKE2b-256 bc32d66093a473d2e579da4afe08b3017561ce97136db57b7ebe5cfa8db20eac

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