Skip to main content

Run-time type checker for Python

Project description

Build Status Code Coverage Documentation

This library provides run-time type checking for functions defined with PEP 484 argument (and return) type annotations, and any arbitrary objects. It can be used together with static type checkers as an additional layer of type safety, to catch type violations that could only be detected at run time.

Two principal ways to do type checking are provided:

  1. The check_type function:

    • like isinstance(), but supports arbitrary type annotations (within limits)

    • can be used as a cast() replacement, but with actual checking of the value

  2. Code instrumentation:

    • entire modules, or individual functions (via @typechecked) are recompiled, with type checking code injected into them

    • automatically checks function arguments, return values and assignments to annotated local variables

    • for generator functions (regular and async), checks yield and send values

    • requires the original source code of the instrumented module(s) to be accessible

Two options are provided for code instrumentation:

  1. the @typechecked function:

    • can be applied to functions individually

  2. the import hook (typeguard.importhook.install_import_hook()):

    • automatically instruments targeted modules on import

    • no manual code changes required in the target modules

    • requires the import hook to be installed before the targeted modules are imported

    • may clash with other import hooks

See the documentation for further information.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

typeguard-3.0.0rc1.tar.gz (54.6 kB view details)

Uploaded Source

Built Distribution

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

typeguard-3.0.0rc1-py3-none-any.whl (29.4 kB view details)

Uploaded Python 3

File details

Details for the file typeguard-3.0.0rc1.tar.gz.

File metadata

  • Download URL: typeguard-3.0.0rc1.tar.gz
  • Upload date:
  • Size: 54.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.2

File hashes

Hashes for typeguard-3.0.0rc1.tar.gz
Algorithm Hash digest
SHA256 0c48b841b215f6df38af4c9c228f6527d2b6174c16f6b97056f1e465a917e01f
MD5 7160a40308acdb6ae961bc0079270b52
BLAKE2b-256 a670ef34a025c8a95c6bec397cbb1274fb226dcede0fb98fc5546b24b49f1c80

See more details on using hashes here.

File details

Details for the file typeguard-3.0.0rc1-py3-none-any.whl.

File metadata

  • Download URL: typeguard-3.0.0rc1-py3-none-any.whl
  • Upload date:
  • Size: 29.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.11.2

File hashes

Hashes for typeguard-3.0.0rc1-py3-none-any.whl
Algorithm Hash digest
SHA256 61781ca94d06156174428a92f8031f9aa7870ae945c72389fc06a332f4885090
MD5 d0f3712e7844c876a79c31e4150c82ca
BLAKE2b-256 46a0a49aee09c4d3749229f3c3c9d26099d900122e63d837306643a232d4c0a5

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