Skip to main content

Generate, fix and convert docstrings.

Project description

Create, update or convert docstrings in existing Python files, managing several styles.

Project Status

Test Status

Build Documentation Status Downloads

License: MIT Code style: black linting: pylint Ruff Checked with pyright pre-commit

Supported Versions

Supports Python39 Supports Python310 Supports Python311 Supports Python312 Supports Python313 Supports Python314

Description

Command-line program to generate, update or transform docstrings in python source code.

The app will parse the requested source files for docstrings as well as function signatures and class bodies.

This information is combined to build up complete docstrings for every function and class including place holders for types and descriptions where none could be found elsewhere.

The output format of the docstrings can be chosen between google, numpy, reST and epydoc. This means that the tool can also be used to transform docstrings in the file from one format into another.

Note however that not all section types are supported for all docstring styles.

Partially because they have not been added yet, but also because not every style officially supports the sections from all others.

To get further information please refer to the documentation.

The tool offers the choice between generating patch files or directly overwriting the python source files.

Start quickly

  • install from PyPi

$ pip install pymend
  • install from sources:

$ pip install git+https://github.com/JanEricNitschke/pymend.git
or
$ git clone https://github.com/JanEricNitschke/pymend.git
$ cd pymend
$ pip install .
or with uv (https://docs.astral.sh/uv/).
$ git clone https://github.com/JanEricNitschke/pymend.git
$ cd pymend
$ uv sync --all-groups
$ uv tool install .
in the case of uv you can prefix all commands below with `uv run`.
  • run from the command line:

$ pymend  myfile.py         # will generate a patch
$ pymend --write myfile.py  # will overwrite the file
  • get help:

$ pymend -h

Example

To see how pymend looks in action lets consider this example file example.py:

"""_summary_."""
 def my_func(param0, param01: int, param1: str = "Some value", param2: List[str] = {}):
     """_summary_.

     Args:
         param0 (_type_): _description_
         param01 (int): _description_
         param1 (str, optional): _description_. Defaults to "Some value".
         param2 (List[str], optional): _description_. Defaults to {}.
     """
     pass


 def my_single_return_func1() -> str:
     """_summary_.

     Returns
     -------
     int
         Wrong
     """
     pass


 def my_multi_return_func() -> Tuple[int, str, bool]:
     """_summary_.

     Returns
     -------
     x :
         Some integer
     y : str
         Some string
     z : bool
         Some bool
     """
     pass

class A:
   def method(self, param1, param2=None) -> int:
         pass

Now let’s use Pymend:

$ pymend example.py

This produces the following patch file example.py.patch:

# Patch generated by Pymend v3.1.0

--- a/example.py
+++ b/example.py
@@ -2,11 +2,16 @@
def my_func(param0, param01: int, param1: str = "Some value", param2: List[str] = {}):
   """_summary_.

-    Args:
-        param0 (_type_): _description_
-        param01 (int): _description_
-        param1 (str, optional): _description_. Defaults to "Some value".
-        param2 (List[str], optional): _description_. Defaults to {}.
+    Parameters
+    ----------
+    param0 : _type_
+        _description_
+    param01 : int
+        _description_
+    param1 : str
+        _description_. Defaults to "Some value".
+    param2 : List[str]
+        _description_. Defaults to {}.
   """
   pass

@@ -16,7 +21,7 @@

   Returns
   -------
-    int
+    str
         Wrong
   """
   pass
@@ -27,7 +32,7 @@

   Returns
   -------
-    x :
+    x : _type_
         Some integer
   y : str
         Some string
@@ -37,5 +42,21 @@
   pass

class A:
+    """_summary_.
+
+    Methods
+    -------
+    method(param1, param2=None)
+        _description_
+    """
   def method(self, param1, param2=None) -> int:
+        """_summary_.
+
+        Parameters
+        ----------
+        param1 : _type_
+            _description_
+        param2 : _type_
+            _description_ (Default value = None)
+        """
         pass

Calling pymend directly with

$ pymend --write example.py

prints out this information about changed files

$ Modified docstrings of elements (my_func, my_single_return_func1, my_multi_return_func, A, method) in file example.py.

and results in the final file (the same we would have gotten when applying the patch):

"""_summary_."""
def my_func(param0, param01: int, param1: str = "Some value", param2: List[str] = {}):
   """_summary_.

   Parameters
   ----------
   param0 : _type_
      _description_
   param01 : int
      _description_
   param1 : str
      _description_. Defaults to "Some value".
   param2 : List[str]
      _description_. Defaults to {}.
   """
   pass


def my_single_return_func1() -> str:
   """_summary_.

   Returns
   -------
   str
      Wrong
   """
   pass


def my_multi_return_func() -> Tuple[int, str, bool]:
   """_summary_.

   Returns
   -------
   x : _type_
      Some integer
   y : str
      Some string
   z : bool
      Some bool
   """
   pass

class A:
   """_summary_.

   Methods
   -------
   method(param1, param2=None)
      _description_
   """
   def method(self, param1, param2=None) -> int:
      """_summary_.

      Parameters
      ----------
      param1 : _type_
            _description_
      param2 : _type_
            _description_ (Default value = None)
      """
      pass

Exit codes

PyMend uses exit codes to indicate the result:

  • 0: All files well formatted, no issues

  • 1: One or more files had issues (would be reformatted or have problems)

  • 2: Usage error (e.g. invalid or conflicting command-line options)

  • 123: Internal error occurred

$ pymend src/
All done! ✨ 🍰 ✨
5 files would be left unchanged.
$ echo $?
0

$ pymend src/
would reformat src/main.py
Oh no! 💥 💔 💥
1 file would be reformatted.
$ echo $?
1

$ pymend src/
error: cannot format src/main.py: INTERNAL ERROR
Oh no! 💥 💔 💥
1 file would fail to reformat.
$ echo $?
123

Pre-commit

To use pymend in a pre-commit hook just add the following to your .pre-commit-config.yaml

repos:
-   repo: https://github.com/JanEricNitschke/pymend
    rev: "v3.1.0"
    hooks:
    -   id: pymend
        language: python
        args: ["--write"]

Acknowledgements

This project was inspired by and is originally based upon pyment. The intended functionality as well as the main entry point remain largely unchanged. However additional functionality has been added in the form of ast traversal for extracting function and class information.

The docstring parsing has been replaced completely with code taken from the awesome docstring_parser project, specifically this fork.

So far only minor modifications have been made to the docstring parsing functionality. Mainly the addition of the “Methods” section for numpydoc style docstrings. Additionally the code has been linted as well as type hinted.

The code for configuration and file handling as well as the structure of the documentation is more or less taken directly from black.

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

pymend-3.1.0.tar.gz (67.4 kB view details)

Uploaded Source

Built Distribution

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

pymend-3.1.0-py3-none-any.whl (76.0 kB view details)

Uploaded Python 3

File details

Details for the file pymend-3.1.0.tar.gz.

File metadata

  • Download URL: pymend-3.1.0.tar.gz
  • Upload date:
  • Size: 67.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for pymend-3.1.0.tar.gz
Algorithm Hash digest
SHA256 f641f0760fcf084ec8e14706ce56b3fef3d806a09d836890ff49b64136e3e40e
MD5 e0965a903497ce609f714f162f4e3188
BLAKE2b-256 4223ef9e230d7bc02d7da18a01b29f21ab7a993bc20f37e524ed2a3582f0f903

See more details on using hashes here.

Provenance

The following attestation bundles were made for pymend-3.1.0.tar.gz:

Publisher: release.yaml on JanEricNitschke/pymend

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pymend-3.1.0-py3-none-any.whl.

File metadata

  • Download URL: pymend-3.1.0-py3-none-any.whl
  • Upload date:
  • Size: 76.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for pymend-3.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6877eaeb9506060600f5ca171dfb59390ec29eace9d74a737e70b27a77e2b9b3
MD5 8f0dab17fab9a48121747f49420baa33
BLAKE2b-256 1f5ca824970f910a62d543814e85cdbdeac800c4b55ae668a05a93532da7d874

See more details on using hashes here.

Provenance

The following attestation bundles were made for pymend-3.1.0-py3-none-any.whl:

Publisher: release.yaml on JanEricNitschke/pymend

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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