Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ilevkivskyi/typing_inspect
Runtime inspection utilities for Python typing module
https://github.com/ilevkivskyi/typing_inspect
introspection python python3 type-hints typing
Last synced: 5 days ago
JSON representation
Runtime inspection utilities for Python typing module
- Host: GitHub
- URL: https://github.com/ilevkivskyi/typing_inspect
- Owner: ilevkivskyi
- License: mit
- Created: 2017-04-29T15:49:25.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2024-08-13T21:13:00.000Z (5 months ago)
- Last Synced: 2025-01-15T06:57:43.035Z (6 days ago)
- Topics: introspection, python, python3, type-hints, typing
- Language: Python
- Homepage:
- Size: 76.2 KB
- Stars: 352
- Watchers: 13
- Forks: 35
- Open Issues: 23
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-python-typing - typing-inspect - The typing_inspect module defines experimental API for runtime inspection of types defined in the `typing` module. (Tools / Working with types)
README
Typing Inspect
==============[![Build Status](https://travis-ci.org/ilevkivskyi/typing_inspect.svg)](https://travis-ci.org/ilevkivskyi/typing_inspect)
The ``typing_inspect`` module defines experimental API for runtime
inspection of types defined in the Python standard ``typing`` module.
Works with ``typing`` version ``3.7.4`` and later. Example usage:```python
from typing import Generic, TypeVar, Iterable, Mapping, Union
from typing_inspect import is_generic_typeT = TypeVar('T')
class MyCollection(Generic[T]):
content: Tassert is_generic_type(Mapping)
assert is_generic_type(Iterable[int])
assert is_generic_type(MyCollection[T])assert not is_generic_type(int)
assert not is_generic_type(Union[int, T])
```**Note**: The API is still experimental, if you have ideas/suggestions please
open an issue on [tracker](https://github.com/ilevkivskyi/typing_inspect/issues).
Currently ``typing_inspect`` only supports latest version of ``typing``. This
limitation may be lifted if such requests will appear frequently.Currently provided functions (see functions docstrings for examples of usage):
* ``is_generic_type(tp)``:
Test if ``tp`` is a generic type. This includes ``Generic`` itself,
but excludes special typing constructs such as ``Union``, ``Tuple``,
``Callable``, ``ClassVar``.
* ``is_callable_type(tp)``:
Test ``tp`` is a generic callable type, including subclasses
excluding non-generic types and callables.
* ``is_tuple_type(tp)``:
Test if ``tp`` is a generic tuple type, including subclasses excluding
non-generic classes.
* ``is_union_type(tp)``:
Test if ``tp`` is a union type.
* ``is_optional_type(tp)``:
Test if ``tp`` is an optional type (either ``type(None)`` or a direct union to it such as in ``Optional[int]``). Nesting and ``TypeVar``s are not unfolded/inspected in this process.
* ``is_literal_type(tp)``:
Test if ``tp`` is a literal type.
* ``is_final_type(tp)``:
Test if ``tp`` is a final type.
* ``is_typevar(tp)``:
Test if ``tp`` represents a type variable.
* ``is_new_type(tp)``:
Test if ``tp`` represents a distinct type.
* ``is_classvar(tp)``:
Test if ``tp`` represents a class variable.
* ``get_origin(tp)``:
Get the unsubscripted version of ``tp``. Supports generic types, ``Union``,
``Callable``, and ``Tuple``. Returns ``None`` for unsupported types.
* ``get_last_origin(tp)``:
Get the last base of (multiply) subscripted type ``tp``. Supports generic
types, ``Union``, ``Callable``, and ``Tuple``. Returns ``None`` for
unsupported types.
* ``get_parameters(tp)``:
Return type parameters of a parameterizable type ``tp`` as a tuple
in lexicographic order. Parameterizable types are generic types,
unions, tuple types and callable types.
* ``get_args(tp, evaluate=False)``:
Get type arguments of ``tp`` with all substitutions performed. For unions,
basic simplifications used by ``Union`` constructor are performed.
If ``evaluate`` is ``False`` (default), report result as nested tuple,
this matches the internal representation of types. If ``evaluate`` is
``True``, then all type parameters are applied (this could be time and
memory expensive).
* ``get_last_args(tp)``:
Get last arguments of (multiply) subscripted type ``tp``.
Parameters for ``Callable`` are flattened.
* ``get_generic_type(obj)``:
Get the generic type of ``obj`` if possible, or its runtime class otherwise.
* ``get_generic_bases(tp)``:
Get generic base types of ``tp`` or empty tuple if not possible.
* ``typed_dict_keys(td)``:
Get ``TypedDict`` keys and their types, or None if ``td`` is not a typed dict.