Skip to main content

Generating type annotations from sampled production types

Project description

MonkeyType

MonkeyType collects runtime types of function arguments and return values, and can automatically generate stub files or even add draft type annotations directly to your Python code based on the types collected at runtime.

Examples

Run a script under call-trace logging of functions and methods in all imported modules:

$ monkeytype run myscript.py

Or enable call-trace logging for a block of code:

import monkeytype

with monkeytype.trace():
    ...

By default this will dump call traces into a sqlite database in the file monkeytype.sqlite3 in the current working directory. You can then use the monkeytype command to generate a stub file for a module, or apply the type annotations directly to your code:

$ monkeytype stub some.module
$ monkeytype apply some.module

Requirements

MonkeyType requires Python 3.6+ and the retype library (for applying type stubs to code files). It generates only Python 3 type annotations (no type comments).

Installing

Install MonkeyType with pip:

pip install MonkeyType

How MonkeyType works

MonkeyType uses the sys.setprofile hook provided by Python to interpose on function calls, function returns, and generator yields, and record the types of arguments / return values / yield values.

It generates stub files based on that data, and can use retype to apply those stub files directly to your code.

See the full documentation for details.

LICENSE

MonkeyType is BSD licensed. We also provide an additional patent grant.

Changelog

17.12.2

  • Exclude “frozen importlib” functions in default code filter.

  • Fix passing args to script run with monkeytype run (#18; merge of #21).

  • Fix generated annotations for NewType types (#22; merge of #23).

17.12.1

  • Fix using MonkeyType outside a virtualenv (#16).

17.12.0

  • Initial public version.

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

MonkeyType-17.12.2.tar.gz (20.5 kB view details)

Uploaded Source

Built Distribution

MonkeyType-17.12.2-py3-none-any.whl (27.7 kB view details)

Uploaded Python 3

File details

Details for the file MonkeyType-17.12.2.tar.gz.

File metadata

File hashes

Hashes for MonkeyType-17.12.2.tar.gz
Algorithm Hash digest
SHA256 c16d5a054db12a90e0a7e19c8f48d752aaf366bea938b516c7a39d1e2b3a43a5
MD5 9ede1f968d49b183615fa5eaa8033f6d
BLAKE2b-256 cc97f5d2957fa234b505bd0e07be250def66c0724032dc9f28aa0a79bd7ce8fa

See more details on using hashes here.

File details

Details for the file MonkeyType-17.12.2-py3-none-any.whl.

File metadata

File hashes

Hashes for MonkeyType-17.12.2-py3-none-any.whl
Algorithm Hash digest
SHA256 78a8f771c1ffd637ce91d77aeeb69ad32829c61224e7b5ea4d25e81d9f4ef5ec
MD5 bb7fa442d67cc42509427f2118e22726
BLAKE2b-256 b502ddc6cc060f2575643ac878ad535c6a5adfc4a1a8b4bb94f2ae2e0663a15f

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