| 
									
										
										
										
											2015-05-22 10:14:11 -07:00
										 |  |  | :mod:`typing` --- Support for type hints
 | 
					
						
							|  |  |  | ========================================
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. module:: typing
 | 
					
						
							|  |  |  |    :synopsis: Support for type hints (see PEP 484).
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-11 16:23:22 +02:00
										 |  |  | .. versionadded:: 3.5
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-11 15:02:54 -04:00
										 |  |  | **Source code:** :source:`Lib/typing.py`
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-20 10:13:23 -05:00
										 |  |  | .. note::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    The typing module has been included in the standard library on a
 | 
					
						
							|  |  |  |    :term:`provisional basis <provisional api>`. New features might
 | 
					
						
							|  |  |  |    be added and API may change even between minor releases if deemed
 | 
					
						
							|  |  |  |    necessary by the core developers.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-22 10:14:11 -07:00
										 |  |  | --------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-08 20:09:56 -07:00
										 |  |  | This module supports type hints as specified by :pep:`484` and :pep:`526`.
 | 
					
						
							| 
									
										
										
										
											2016-11-11 15:57:09 -08:00
										 |  |  | The most fundamental support consists of the types :data:`Any`, :data:`Union`,
 | 
					
						
							| 
									
										
										
										
											2016-10-08 20:06:56 -07:00
										 |  |  | :data:`Tuple`, :data:`Callable`, :class:`TypeVar`, and
 | 
					
						
							| 
									
										
										
										
											2015-05-22 10:14:11 -07:00
										 |  |  | :class:`Generic`.  For full specification please see :pep:`484`.  For
 | 
					
						
							|  |  |  | a simplified introduction to type hints see :pep:`483`.
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The function below takes and returns a string and is annotated as follows::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    def greeting(name: str) -> str:
 | 
					
						
							|  |  |  |        return 'Hello ' + name
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-02-02 17:04:41 -06:00
										 |  |  | In the function ``greeting``, the argument ``name`` is expected to be of type
 | 
					
						
							| 
									
										
										
										
											2015-08-29 22:39:47 -05:00
										 |  |  | :class:`str` and the return type :class:`str`. Subtypes are accepted as
 | 
					
						
							|  |  |  | arguments.
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | Type aliases
 | 
					
						
							|  |  |  | ------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-29 15:38:14 -07:00
										 |  |  | A type alias is defined by assigning the type to the alias. In this example,
 | 
					
						
							|  |  |  | ``Vector`` and ``List[float]`` will be treated as interchangeable synonyms::
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-29 15:38:14 -07:00
										 |  |  |    from typing import List
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  |    Vector = List[float]
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-29 15:38:14 -07:00
										 |  |  |    def scale(scalar: float, vector: Vector) -> Vector:
 | 
					
						
							|  |  |  |        return [scalar * num for num in vector]
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    # typechecks; a list of floats qualifies as a Vector.
 | 
					
						
							|  |  |  |    new_vector = scale(2.0, [1.0, -4.2, 5.4])
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Type aliases are useful for simplifying complex type signatures. For example::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    from typing import Dict, Tuple, List
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    ConnectionOptions = Dict[str, str]
 | 
					
						
							|  |  |  |    Address = Tuple[str, int]
 | 
					
						
							|  |  |  |    Server = Tuple[Address, ConnectionOptions]
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    def broadcast_message(message: str, servers: List[Server]) -> None:
 | 
					
						
							|  |  |  |        ...
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    # The static type checker will treat the previous type signature as
 | 
					
						
							|  |  |  |    # being exactly equivalent to this one.
 | 
					
						
							|  |  |  |    def broadcast_message(
 | 
					
						
							|  |  |  |            message: str,
 | 
					
						
							|  |  |  |            servers: List[Tuple[Tuple[str, int], Dict[str, str]]]) -> None:
 | 
					
						
							|  |  |  |        ...
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-10 18:49:14 -07:00
										 |  |  | Note that ``None`` as a type hint is a special case and is replaced by
 | 
					
						
							|  |  |  | ``type(None)``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-10 18:54:14 -07:00
										 |  |  | .. _distinct:
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-29 15:38:14 -07:00
										 |  |  | NewType
 | 
					
						
							|  |  |  | -------
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-10 18:54:14 -07:00
										 |  |  | Use the :func:`NewType` helper function to create distinct types::
 | 
					
						
							| 
									
										
										
										
											2016-07-29 15:38:14 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |    from typing import NewType
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    UserId = NewType('UserId', int)
 | 
					
						
							|  |  |  |    some_id = UserId(524313)
 | 
					
						
							| 
									
										
										
										
											2016-07-29 15:41:17 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-29 15:38:14 -07:00
										 |  |  | The static type checker will treat the new type as if it were a subclass
 | 
					
						
							|  |  |  | of the original type. This is useful in helping catch logical errors::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    def get_user_name(user_id: UserId) -> str:
 | 
					
						
							|  |  |  |        ...
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    # typechecks
 | 
					
						
							|  |  |  |    user_a = get_user_name(UserId(42351))
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    # does not typecheck; an int is not a UserId
 | 
					
						
							|  |  |  |    user_b = get_user_name(-1)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | You may still perform all ``int`` operations on a variable of type ``UserId``,
 | 
					
						
							|  |  |  | but the result will always be of type ``int``. This lets you pass in a
 | 
					
						
							|  |  |  | ``UserId`` wherever an ``int`` might be expected, but will prevent you from
 | 
					
						
							|  |  |  | accidentally creating a ``UserId`` in an invalid way::
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-30 03:47:52 +03:00
										 |  |  |    # 'output' is of type 'int', not 'UserId'
 | 
					
						
							| 
									
										
										
										
											2016-07-29 15:38:14 -07:00
										 |  |  |    output = UserId(23413) + UserId(54341)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Note that these checks are enforced only by the static type checker. At runtime
 | 
					
						
							|  |  |  | the statement ``Derived = NewType('Derived', Base)`` will make ``Derived`` a
 | 
					
						
							|  |  |  | function that immediately returns whatever parameter you pass it. That means
 | 
					
						
							|  |  |  | the expression ``Derived(some_value)`` does not create a new class or introduce
 | 
					
						
							|  |  |  | any overhead beyond that of a regular function call.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | More precisely, the expression ``some_value is Derived(some_value)`` is always
 | 
					
						
							|  |  |  | true at runtime.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | This also means that it is not possible to create a subtype of ``Derived``
 | 
					
						
							| 
									
										
										
										
											2017-09-24 04:37:48 +02:00
										 |  |  | since it is an identity function at runtime, not an actual type::
 | 
					
						
							| 
									
										
										
										
											2016-07-29 15:38:14 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |    from typing import NewType
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    UserId = NewType('UserId', int)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    # Fails at runtime and does not typecheck
 | 
					
						
							|  |  |  |    class AdminUserId(UserId): pass
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-24 04:37:48 +02:00
										 |  |  | However, it is possible to create a :func:`NewType` based on a 'derived' ``NewType``::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    from typing import NewType
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    UserId = NewType('UserId', int)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-29 15:38:14 -07:00
										 |  |  |    ProUserId = NewType('ProUserId', UserId)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-24 04:37:48 +02:00
										 |  |  | and typechecking for ``ProUserId`` will work as expected.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-29 15:38:14 -07:00
										 |  |  | See :pep:`484` for more details.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. note::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Recall that the use of a type alias declares two types to be *equivalent* to
 | 
					
						
							|  |  |  |    one another. Doing ``Alias = Original`` will make the static type checker
 | 
					
						
							|  |  |  |    treat ``Alias`` as being *exactly equivalent* to ``Original`` in all cases.
 | 
					
						
							|  |  |  |    This is useful when you want to simplify complex type signatures.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    In contrast, ``NewType`` declares one type to be a *subtype* of another.
 | 
					
						
							|  |  |  |    Doing ``Derived = NewType('Derived', Original)`` will make the static type
 | 
					
						
							|  |  |  |    checker treat ``Derived`` as a *subclass* of ``Original``, which means a
 | 
					
						
							|  |  |  |    value of type ``Original`` cannot be used in places where a value of type
 | 
					
						
							|  |  |  |    ``Derived`` is expected. This is useful when you want to prevent logic
 | 
					
						
							|  |  |  |    errors with minimal runtime cost.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-26 23:23:02 +01:00
										 |  |  | .. versionadded:: 3.5.2
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | Callable
 | 
					
						
							|  |  |  | --------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Frameworks expecting callback functions of specific signatures might be
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  | type hinted using ``Callable[[Arg1Type, Arg2Type], ReturnType]``.
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | For example::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    from typing import Callable
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    def feeder(get_next_item: Callable[[], str]) -> None:
 | 
					
						
							|  |  |  |        # Body
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    def async_query(on_success: Callable[[int], None],
 | 
					
						
							|  |  |  |                    on_error: Callable[[int, Exception], None]) -> None:
 | 
					
						
							|  |  |  |        # Body
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-05 12:26:07 +02:00
										 |  |  | It is possible to declare the return type of a callable without specifying
 | 
					
						
							|  |  |  | the call signature by substituting a literal ellipsis
 | 
					
						
							| 
									
										
										
										
											2015-08-29 22:39:47 -05:00
										 |  |  | for the list of arguments in the type hint: ``Callable[..., ReturnType]``.
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | Generics
 | 
					
						
							|  |  |  | --------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Since type information about objects kept in containers cannot be statically
 | 
					
						
							|  |  |  | inferred in a generic way, abstract base classes have been extended to support
 | 
					
						
							|  |  |  | subscription to denote expected types for container elements.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-10 21:55:50 +03:00
										 |  |  | ::
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |    from typing import Mapping, Sequence
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    def notify_by_email(employees: Sequence[Employee],
 | 
					
						
							|  |  |  |                        overrides: Mapping[str, str]) -> None: ...
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Generics can be parametrized by using a new factory available in typing
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  | called :class:`TypeVar`.
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-10 21:55:50 +03:00
										 |  |  | ::
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |    from typing import Sequence, TypeVar
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    T = TypeVar('T')      # Declare type variable
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    def first(l: Sequence[T]) -> T:   # Generic function
 | 
					
						
							|  |  |  |        return l[0]
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | User-defined generic types
 | 
					
						
							|  |  |  | --------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | A user-defined class can be defined as a generic class.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-10 21:55:50 +03:00
										 |  |  | ::
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |    from typing import TypeVar, Generic
 | 
					
						
							|  |  |  |    from logging import Logger
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    T = TypeVar('T')
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    class LoggedVar(Generic[T]):
 | 
					
						
							|  |  |  |        def __init__(self, value: T, name: str, logger: Logger) -> None:
 | 
					
						
							|  |  |  |            self.name = name
 | 
					
						
							|  |  |  |            self.logger = logger
 | 
					
						
							|  |  |  |            self.value = value
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        def set(self, new: T) -> None:
 | 
					
						
							|  |  |  |            self.log('Set ' + repr(self.value))
 | 
					
						
							|  |  |  |            self.value = new
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        def get(self) -> T:
 | 
					
						
							|  |  |  |            self.log('Get ' + repr(self.value))
 | 
					
						
							|  |  |  |            return self.value
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        def log(self, message: str) -> None:
 | 
					
						
							| 
									
										
										
										
											2016-08-31 08:22:29 +01:00
										 |  |  |            self.logger.info('%s: %s', self.name, message)
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-29 22:39:47 -05:00
										 |  |  | ``Generic[T]`` as a base class defines that the class ``LoggedVar`` takes a
 | 
					
						
							|  |  |  | single type parameter ``T`` . This also makes ``T`` valid as a type within the
 | 
					
						
							|  |  |  | class body.
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-29 22:39:47 -05:00
										 |  |  | The :class:`Generic` base class uses a metaclass that defines
 | 
					
						
							|  |  |  | :meth:`__getitem__` so that ``LoggedVar[t]`` is valid as a type::
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |    from typing import Iterable
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    def zero_all_vars(vars: Iterable[LoggedVar[int]]) -> None:
 | 
					
						
							|  |  |  |        for var in vars:
 | 
					
						
							|  |  |  |            var.set(0)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | A generic type can have any number of type variables, and type variables may
 | 
					
						
							|  |  |  | be constrained::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    from typing import TypeVar, Generic
 | 
					
						
							|  |  |  |    ...
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    T = TypeVar('T')
 | 
					
						
							|  |  |  |    S = TypeVar('S', int, str)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    class StrangePair(Generic[T, S]):
 | 
					
						
							|  |  |  |        ...
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-29 22:39:47 -05:00
										 |  |  | Each type variable argument to :class:`Generic` must be distinct.
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | This is thus invalid::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    from typing import TypeVar, Generic
 | 
					
						
							|  |  |  |    ...
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    T = TypeVar('T')
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    class Pair(Generic[T, T]):   # INVALID
 | 
					
						
							|  |  |  |        ...
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  | You can use multiple inheritance with :class:`Generic`::
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |    from typing import TypeVar, Generic, Sized
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    T = TypeVar('T')
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    class LinkedList(Sized, Generic[T]):
 | 
					
						
							|  |  |  |        ...
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-05-29 04:13:35 +00:00
										 |  |  | When inheriting from generic classes, some type variables could be fixed::
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     from typing import TypeVar, Mapping
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     T = TypeVar('T')
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     class MyDict(Mapping[str, T]):
 | 
					
						
							|  |  |  |         ...
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | In this case ``MyDict`` has a single parameter, ``T``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-08 20:06:56 -07:00
										 |  |  | Using a generic class without specifying type parameters assumes
 | 
					
						
							|  |  |  | :data:`Any` for each position. In the following example, ``MyIterable`` is
 | 
					
						
							| 
									
										
										
										
											2015-08-29 22:39:47 -05:00
										 |  |  | not generic but implicitly inherits from ``Iterable[Any]``::
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |    from typing import Iterable
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    class MyIterable(Iterable): # Same as Iterable[Any]
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-11 15:54:04 -08:00
										 |  |  | User defined generic type aliases are also supported. Examples::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    from typing import TypeVar, Iterable, Tuple, Union
 | 
					
						
							|  |  |  |    S = TypeVar('S')
 | 
					
						
							|  |  |  |    Response = Union[Iterable[S], int]
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    # Return type here is same as Union[Iterable[str], int]
 | 
					
						
							|  |  |  |    def response(query: str) -> Response[str]:
 | 
					
						
							|  |  |  |        ...
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    T = TypeVar('T', int, float, complex)
 | 
					
						
							|  |  |  |    Vec = Iterable[Tuple[T, T]]
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    def inproduct(v: Vec[T]) -> T: # Same as Iterable[Tuple[T, T]]
 | 
					
						
							|  |  |  |        return sum(x*y for x, y in v)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  | The metaclass used by :class:`Generic` is a subclass of :class:`abc.ABCMeta`.
 | 
					
						
							|  |  |  | A generic class can be an ABC by including abstract methods or properties,
 | 
					
						
							|  |  |  | and generic classes can also have ABCs as base classes without a metaclass
 | 
					
						
							| 
									
										
										
										
											2016-10-08 20:06:56 -07:00
										 |  |  | conflict. Generic metaclasses are not supported. The outcome of parameterizing
 | 
					
						
							|  |  |  | generics is cached, and most types in the typing module are hashable and
 | 
					
						
							|  |  |  | comparable for equality.
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-08 20:06:56 -07:00
										 |  |  | The :data:`Any` type
 | 
					
						
							| 
									
										
										
										
											2017-02-04 09:34:16 +03:00
										 |  |  | --------------------
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-08 20:06:56 -07:00
										 |  |  | A special kind of type is :data:`Any`. A static type checker will treat
 | 
					
						
							|  |  |  | every type as being compatible with :data:`Any` and :data:`Any` as being
 | 
					
						
							| 
									
										
										
										
											2016-08-06 13:46:48 -07:00
										 |  |  | compatible with every type.
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-06 13:46:48 -07:00
										 |  |  | This means that it is possible to perform any operation or method call on a
 | 
					
						
							| 
									
										
										
										
											2016-10-08 20:06:56 -07:00
										 |  |  | value of type on :data:`Any` and assign it to any variable::
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-06 13:46:48 -07:00
										 |  |  |    from typing import Any
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    a = None    # type: Any
 | 
					
						
							|  |  |  |    a = []      # OK
 | 
					
						
							|  |  |  |    a = 2       # OK
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    s = ''      # type: str
 | 
					
						
							|  |  |  |    s = a       # OK
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    def foo(item: Any) -> int:
 | 
					
						
							| 
									
										
										
										
											2016-08-08 13:34:49 +03:00
										 |  |  |        # Typechecks; 'item' could be any type,
 | 
					
						
							|  |  |  |        # and that type might have a 'bar' method
 | 
					
						
							| 
									
										
										
										
											2016-08-06 13:46:48 -07:00
										 |  |  |        item.bar()
 | 
					
						
							|  |  |  |        ...
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Notice that no typechecking is performed when assigning a value of type
 | 
					
						
							| 
									
										
										
										
											2016-10-08 20:06:56 -07:00
										 |  |  | :data:`Any` to a more precise type. For example, the static type checker did
 | 
					
						
							| 
									
										
										
										
											2016-08-06 13:46:48 -07:00
										 |  |  | not report an error when assigning ``a`` to ``s`` even though ``s`` was
 | 
					
						
							|  |  |  | declared to be of type :class:`str` and receives an :class:`int` value at
 | 
					
						
							|  |  |  | runtime!
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Furthermore, all functions without a return type or parameter types will
 | 
					
						
							| 
									
										
										
										
											2016-10-08 20:06:56 -07:00
										 |  |  | implicitly default to using :data:`Any`::
 | 
					
						
							| 
									
										
										
										
											2016-08-06 13:46:48 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |    def legacy_parser(text):
 | 
					
						
							|  |  |  |        ...
 | 
					
						
							|  |  |  |        return data
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    # A static type checker will treat the above
 | 
					
						
							|  |  |  |    # as having the same signature as:
 | 
					
						
							|  |  |  |    def legacy_parser(text: Any) -> Any:
 | 
					
						
							|  |  |  |        ...
 | 
					
						
							|  |  |  |        return data
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-08 20:06:56 -07:00
										 |  |  | This behavior allows :data:`Any` to be used as an *escape hatch* when you
 | 
					
						
							| 
									
										
										
										
											2016-08-06 13:46:48 -07:00
										 |  |  | need to mix dynamically and statically typed code.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-08 20:06:56 -07:00
										 |  |  | Contrast the behavior of :data:`Any` with the behavior of :class:`object`.
 | 
					
						
							|  |  |  | Similar to :data:`Any`, every type is a subtype of :class:`object`. However,
 | 
					
						
							|  |  |  | unlike :data:`Any`, the reverse is not true: :class:`object` is *not* a
 | 
					
						
							| 
									
										
										
										
											2016-08-06 13:46:48 -07:00
										 |  |  | subtype of every other type.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | That means when the type of a value is :class:`object`, a type checker will
 | 
					
						
							|  |  |  | reject almost all operations on it, and assigning it to a variable (or using
 | 
					
						
							|  |  |  | it as a return value) of a more specialized type is a type error. For example::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    def hash_a(item: object) -> int:
 | 
					
						
							| 
									
										
										
										
											2016-08-08 13:34:49 +03:00
										 |  |  |        # Fails; an object does not have a 'magic' method.
 | 
					
						
							| 
									
										
										
										
											2016-08-06 13:46:48 -07:00
										 |  |  |        item.magic()
 | 
					
						
							|  |  |  |        ...
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    def hash_b(item: Any) -> int:
 | 
					
						
							|  |  |  |        # Typechecks
 | 
					
						
							|  |  |  |        item.magic()
 | 
					
						
							|  |  |  |        ...
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    # Typechecks, since ints and strs are subclasses of object
 | 
					
						
							|  |  |  |    hash_a(42)
 | 
					
						
							|  |  |  |    hash_a("foo")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    # Typechecks, since Any is compatible with all types
 | 
					
						
							|  |  |  |    hash_b(42)
 | 
					
						
							|  |  |  |    hash_b("foo")
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Use :class:`object` to indicate that a value could be any type in a typesafe
 | 
					
						
							| 
									
										
										
										
											2016-10-08 20:06:56 -07:00
										 |  |  | manner. Use :data:`Any` to indicate that a value is dynamically typed.
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | Classes, functions, and decorators
 | 
					
						
							|  |  |  | ----------------------------------
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The module defines the following classes, functions and decorators:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. class:: TypeVar
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Type variable.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Usage::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       T = TypeVar('T')  # Can be anything
 | 
					
						
							|  |  |  |       A = TypeVar('A', str, bytes)  # Must be str or bytes
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     Type variables exist primarily for the benefit of static type
 | 
					
						
							|  |  |  |     checkers.  They serve as the parameters for generic types as well
 | 
					
						
							|  |  |  |     as for generic function definitions.  See class Generic for more
 | 
					
						
							| 
									
										
										
										
											2015-09-10 21:55:50 +03:00
										 |  |  |     information on generic types.  Generic functions work as follows::
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |        def repeat(x: T, n: int) -> Sequence[T]:
 | 
					
						
							|  |  |  |            """Return a list containing n references to x."""
 | 
					
						
							|  |  |  |            return [x]*n
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        def longest(x: A, y: A) -> A:
 | 
					
						
							|  |  |  |            """Return the longest of two strings."""
 | 
					
						
							|  |  |  |            return x if len(x) >= len(y) else y
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     The latter example's signature is essentially the overloading
 | 
					
						
							| 
									
										
										
										
											2015-08-29 22:39:47 -05:00
										 |  |  |     of ``(str, str) -> str`` and ``(bytes, bytes) -> bytes``.  Also note
 | 
					
						
							|  |  |  |     that if the arguments are instances of some subclass of :class:`str`,
 | 
					
						
							|  |  |  |     the return type is still plain :class:`str`.
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-29 22:39:47 -05:00
										 |  |  |     At runtime, ``isinstance(x, T)`` will raise :exc:`TypeError`.  In general,
 | 
					
						
							| 
									
										
										
										
											2015-09-10 21:55:50 +03:00
										 |  |  |     :func:`isinstance` and :func:`issubclass` should not be used with types.
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     Type variables may be marked covariant or contravariant by passing
 | 
					
						
							| 
									
										
										
										
											2015-08-29 22:39:47 -05:00
										 |  |  |     ``covariant=True`` or ``contravariant=True``.  See :pep:`484` for more
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  |     details.  By default type variables are invariant.  Alternatively,
 | 
					
						
							|  |  |  |     a type variable may specify an upper bound using ``bound=<type>``.
 | 
					
						
							| 
									
										
										
										
											2015-09-10 21:55:50 +03:00
										 |  |  |     This means that an actual type substituted (explicitly or implicitly)
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  |     for the type variable must be a subclass of the boundary type,
 | 
					
						
							|  |  |  |     see :pep:`484`.
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | .. class:: Generic
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Abstract base class for generic types.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    A generic type is typically declared by inheriting from an
 | 
					
						
							|  |  |  |    instantiation of this class with one or more type variables.
 | 
					
						
							|  |  |  |    For example, a generic mapping type might be defined as::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       class Mapping(Generic[KT, VT]):
 | 
					
						
							|  |  |  |           def __getitem__(self, key: KT) -> VT:
 | 
					
						
							|  |  |  |               ...
 | 
					
						
							|  |  |  |               # Etc.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    This class can then be used as follows::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       X = TypeVar('X')
 | 
					
						
							|  |  |  |       Y = TypeVar('Y')
 | 
					
						
							| 
									
										
										
										
											2015-09-10 21:55:50 +03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  |       def lookup_name(mapping: Mapping[X, Y], key: X, default: Y) -> Y:
 | 
					
						
							|  |  |  |           try:
 | 
					
						
							|  |  |  |               return mapping[key]
 | 
					
						
							|  |  |  |           except KeyError:
 | 
					
						
							| 
									
										
										
										
											2015-08-05 12:26:07 +02:00
										 |  |  |               return default
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-08 20:06:56 -07:00
										 |  |  | .. class:: Type(Generic[CT_co])
 | 
					
						
							| 
									
										
										
										
											2016-09-06 21:12:44 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |    A variable annotated with ``C`` may accept a value of type ``C``. In
 | 
					
						
							|  |  |  |    contrast, a variable annotated with ``Type[C]`` may accept values that are
 | 
					
						
							|  |  |  |    classes themselves -- specifically, it will accept the *class object* of
 | 
					
						
							|  |  |  |    ``C``. For example::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       a = 3         # Has type 'int'
 | 
					
						
							|  |  |  |       b = int       # Has type 'Type[int]'
 | 
					
						
							|  |  |  |       c = type(a)   # Also has type 'Type[int]'
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Note that ``Type[C]`` is covariant::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       class User: ...
 | 
					
						
							|  |  |  |       class BasicUser(User): ...
 | 
					
						
							|  |  |  |       class ProUser(User): ...
 | 
					
						
							|  |  |  |       class TeamUser(User): ...
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       # Accepts User, BasicUser, ProUser, TeamUser, ...
 | 
					
						
							|  |  |  |       def make_new_user(user_class: Type[User]) -> User:
 | 
					
						
							|  |  |  |           # ...
 | 
					
						
							|  |  |  |           return user_class()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    The fact that ``Type[C]`` is covariant implies that all subclasses of
 | 
					
						
							|  |  |  |    ``C`` should implement the same constructor signature and class method
 | 
					
						
							|  |  |  |    signatures as ``C``. The type checker should flag violations of this,
 | 
					
						
							|  |  |  |    but should also allow constructor calls in subclasses that match the
 | 
					
						
							|  |  |  |    constructor calls in the indicated base class. How the type checker is
 | 
					
						
							|  |  |  |    required to handle this particular case may change in future revisions of
 | 
					
						
							| 
									
										
										
										
											2016-09-10 18:54:14 -07:00
										 |  |  |    :pep:`484`.
 | 
					
						
							| 
									
										
										
										
											2016-09-06 21:12:44 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-10 18:54:14 -07:00
										 |  |  |    The only legal parameters for :class:`Type` are classes, unions of classes, and
 | 
					
						
							| 
									
										
										
										
											2016-10-08 20:06:56 -07:00
										 |  |  |    :data:`Any`. For example::
 | 
					
						
							| 
									
										
										
										
											2016-09-06 21:12:44 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |       def new_non_team_user(user_class: Type[Union[BaseUser, ProUser]]): ...
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    ``Type[Any]`` is equivalent to ``Type`` which in turn is equivalent
 | 
					
						
							|  |  |  |    to ``type``, which is the root of Python's metaclass hierarchy.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-26 23:23:02 +01:00
										 |  |  |    .. versionadded:: 3.5.2
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | .. class:: Iterable(Generic[T_co])
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-08 12:15:27 -07:00
										 |  |  |     A generic version of :class:`collections.abc.Iterable`.
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | .. class:: Iterator(Iterable[T_co])
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-08 12:15:27 -07:00
										 |  |  |     A generic version of :class:`collections.abc.Iterator`.
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-04 10:59:29 -07:00
										 |  |  | .. class:: Reversible(Iterable[T_co])
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-08 12:15:27 -07:00
										 |  |  |     A generic version of :class:`collections.abc.Reversible`.
 | 
					
						
							| 
									
										
										
										
											2016-04-04 10:59:29 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | .. class:: SupportsInt
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-10 21:55:50 +03:00
										 |  |  |     An ABC with one abstract method ``__int__``.
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | .. class:: SupportsFloat
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-10 21:55:50 +03:00
										 |  |  |     An ABC with one abstract method ``__float__``.
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-08 09:09:14 -07:00
										 |  |  | .. class:: SupportsComplex
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     An ABC with one abstract method ``__complex__``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. class:: SupportsBytes
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     An ABC with one abstract method ``__bytes__``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | .. class:: SupportsAbs
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-10 21:55:50 +03:00
										 |  |  |     An ABC with one abstract method ``__abs__`` that is covariant
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  |     in its return type.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | .. class:: SupportsRound
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-10 21:55:50 +03:00
										 |  |  |     An ABC with one abstract method ``__round__``
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  |     that is covariant in its return type.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | .. class:: Container(Generic[T_co])
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  |     A generic version of :class:`collections.abc.Container`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-10 18:54:14 -07:00
										 |  |  | .. class:: Hashable
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    An alias to :class:`collections.abc.Hashable`
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. class:: Sized
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    An alias to :class:`collections.abc.Sized`
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. class:: Collection(Sized, Iterable[T_co], Container[T_co])
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    A generic version of :class:`collections.abc.Collection`
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.6
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. class:: AbstractSet(Sized, Collection[T_co])
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  |     A generic version of :class:`collections.abc.Set`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | .. class:: MutableSet(AbstractSet[T])
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  |     A generic version of :class:`collections.abc.MutableSet`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-10 18:54:14 -07:00
										 |  |  | .. class:: Mapping(Sized, Collection[KT], Generic[VT_co])
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     A generic version of :class:`collections.abc.Mapping`.
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | .. class:: MutableMapping(Mapping[KT, VT])
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  |     A generic version of :class:`collections.abc.MutableMapping`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-10 18:54:14 -07:00
										 |  |  | .. class:: Sequence(Reversible[T_co], Collection[T_co])
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  |     A generic version of :class:`collections.abc.Sequence`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | .. class:: MutableSequence(Sequence[T])
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  |    A generic version of :class:`collections.abc.MutableSequence`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | .. class:: ByteString(Sequence[int])
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  |    A generic version of :class:`collections.abc.ByteString`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    This type represents the types :class:`bytes`, :class:`bytearray`,
 | 
					
						
							|  |  |  |    and :class:`memoryview`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    As a shorthand for this type, :class:`bytes` can be used to
 | 
					
						
							|  |  |  |    annotate arguments of any of the types mentioned above.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-16 22:42:37 -08:00
										 |  |  | .. class:: Deque(deque, MutableSequence[T])
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    A generic version of :class:`collections.deque`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-15 11:37:18 -08:00
										 |  |  |    .. versionadded:: 3.6.1
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | .. class:: List(list, MutableSequence[T])
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  |    Generic version of :class:`list`.
 | 
					
						
							|  |  |  |    Useful for annotating return types. To annotate arguments it is preferred
 | 
					
						
							|  |  |  |    to use abstract collection types such as :class:`Mapping`, :class:`Sequence`,
 | 
					
						
							|  |  |  |    or :class:`AbstractSet`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    This type may be used as follows::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       T = TypeVar('T', int, float)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       def vec2(x: T, y: T) -> List[T]:
 | 
					
						
							|  |  |  |           return [x, y]
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-28 10:08:17 -07:00
										 |  |  |       def keep_positives(vector: Sequence[T]) -> List[T]:
 | 
					
						
							|  |  |  |           return [item for item in vector if item > 0]
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-29 14:41:16 +03:00
										 |  |  | .. class:: Set(set, MutableSet[T])
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-29 14:41:16 +03:00
										 |  |  |    A generic version of :class:`builtins.set <set>`.
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-24 11:56:00 -08:00
										 |  |  | .. class:: FrozenSet(frozenset, AbstractSet[T_co])
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    A generic version of :class:`builtins.frozenset <frozenset>`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | .. class:: MappingView(Sized, Iterable[T_co])
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  |    A generic version of :class:`collections.abc.MappingView`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | .. class:: KeysView(MappingView[KT_co], AbstractSet[KT_co])
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  |    A generic version of :class:`collections.abc.KeysView`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | .. class:: ItemsView(MappingView, Generic[KT_co, VT_co])
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  |    A generic version of :class:`collections.abc.ItemsView`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | .. class:: ValuesView(MappingView[VT_co])
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  |    A generic version of :class:`collections.abc.ValuesView`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-09 11:46:34 -07:00
										 |  |  | .. class:: Awaitable(Generic[T_co])
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    A generic version of :class:`collections.abc.Awaitable`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-11 15:54:04 -08:00
										 |  |  | .. class:: Coroutine(Awaitable[V_co], Generic[T_co T_contra, V_co])
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    A generic version of :class:`collections.abc.Coroutine`.
 | 
					
						
							|  |  |  |    The variance and order of type variables
 | 
					
						
							|  |  |  |    correspond to those of :class:`Generator`, for example::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       from typing import List, Coroutine
 | 
					
						
							|  |  |  |       c = None # type: Coroutine[List[str], str, int]
 | 
					
						
							|  |  |  |       ...
 | 
					
						
							|  |  |  |       x = c.send('hi') # type: List[str]
 | 
					
						
							|  |  |  |       async def bar() -> None:
 | 
					
						
							|  |  |  |           x = await c # type: int
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-09 11:46:34 -07:00
										 |  |  | .. class:: AsyncIterable(Generic[T_co])
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    A generic version of :class:`collections.abc.AsyncIterable`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. class:: AsyncIterator(AsyncIterable[T_co])
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-04 09:34:16 +03:00
										 |  |  |    A generic version of :class:`collections.abc.AsyncIterator`.
 | 
					
						
							| 
									
										
										
										
											2016-09-09 11:46:34 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-04-08 12:15:27 -07:00
										 |  |  | .. class:: ContextManager(Generic[T_co])
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    A generic version of :class:`contextlib.AbstractContextManager`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.6
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-14 18:14:07 -04:00
										 |  |  | .. class:: AsyncContextManager(Generic[T_co])
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    A generic version of :class:`contextlib.AbstractAsyncContextManager`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.6
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | .. class:: Dict(dict, MutableMapping[KT, VT])
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  |    A generic version of :class:`dict`.
 | 
					
						
							|  |  |  |    The usage of this type is as follows::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       def get_position_in_index(word_list: Dict[str, int], word: str) -> int:
 | 
					
						
							|  |  |  |           return word_list[word]
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-10 18:54:14 -07:00
										 |  |  | .. class:: DefaultDict(collections.defaultdict, MutableMapping[KT, VT])
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-08 09:09:14 -07:00
										 |  |  |    A generic version of :class:`collections.defaultdict`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-26 23:23:02 +01:00
										 |  |  |    .. versionadded:: 3.5.2
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-08 09:09:14 -07:00
										 |  |  | .. class:: Counter(collections.Counter, Dict[T, int])
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    A generic version of :class:`collections.Counter`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.6.1
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. class:: ChainMap(collections.ChainMap, MutableMapping[KT, VT])
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    A generic version of :class:`collections.ChainMap`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.6.1
 | 
					
						
							| 
									
										
										
										
											2016-09-10 18:54:14 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | .. class:: Generator(Iterator[T_co], Generic[T_co, T_contra, V_co])
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-05 12:56:09 -07:00
										 |  |  |    A generator can be annotated by the generic type
 | 
					
						
							|  |  |  |    ``Generator[YieldType, SendType, ReturnType]``. For example::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       def echo_round() -> Generator[int, float, str]:
 | 
					
						
							|  |  |  |           sent = yield 0
 | 
					
						
							|  |  |  |           while sent >= 0:
 | 
					
						
							|  |  |  |               sent = yield round(sent)
 | 
					
						
							|  |  |  |           return 'Done'
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Note that unlike many other generics in the typing module, the ``SendType``
 | 
					
						
							|  |  |  |    of :class:`Generator` behaves contravariantly, not covariantly or
 | 
					
						
							|  |  |  |    invariantly.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    If your generator will only yield values, set the ``SendType`` and
 | 
					
						
							|  |  |  |    ``ReturnType`` to ``None``::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       def infinite_stream(start: int) -> Generator[int, None, None]:
 | 
					
						
							|  |  |  |           while True:
 | 
					
						
							|  |  |  |               yield start
 | 
					
						
							|  |  |  |               start += 1
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Alternatively, annotate your generator as having a return type of
 | 
					
						
							| 
									
										
										
										
											2016-09-09 11:46:34 -07:00
										 |  |  |    either ``Iterable[YieldType]`` or ``Iterator[YieldType]``::
 | 
					
						
							| 
									
										
										
										
											2016-08-05 12:56:09 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |       def infinite_stream(start: int) -> Iterator[int]:
 | 
					
						
							|  |  |  |           while True:
 | 
					
						
							|  |  |  |               yield start
 | 
					
						
							|  |  |  |               start += 1
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-02-04 09:18:11 +03:00
										 |  |  | .. class:: AsyncGenerator(AsyncIterator[T_co], Generic[T_co, T_contra])
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    An async generator can be annotated by the generic type
 | 
					
						
							|  |  |  |    ``AsyncGenerator[YieldType, SendType]``. For example::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       async def echo_round() -> AsyncGenerator[int, float]:
 | 
					
						
							|  |  |  |           sent = yield 0
 | 
					
						
							|  |  |  |           while sent >= 0.0:
 | 
					
						
							|  |  |  |               rounded = await round(sent)
 | 
					
						
							|  |  |  |               sent = yield rounded
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Unlike normal generators, async generators cannot return a value, so there
 | 
					
						
							|  |  |  |    is no ``ReturnType`` type parameter. As with :class:`Generator`, the
 | 
					
						
							|  |  |  |    ``SendType`` behaves contravariantly.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    If your generator will only yield values, set the ``SendType`` to
 | 
					
						
							|  |  |  |    ``None``::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       async def infinite_stream(start: int) -> AsyncGenerator[int, None]:
 | 
					
						
							|  |  |  |           while True:
 | 
					
						
							|  |  |  |               yield start
 | 
					
						
							|  |  |  |               start = await increment(start)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Alternatively, annotate your generator as having a return type of
 | 
					
						
							|  |  |  |    either ``AsyncIterable[YieldType]`` or ``AsyncIterator[YieldType]``::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       async def infinite_stream(start: int) -> AsyncIterator[int]:
 | 
					
						
							|  |  |  |           while True:
 | 
					
						
							|  |  |  |               yield start
 | 
					
						
							|  |  |  |               start = await increment(start)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.5.4
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-08-15 15:06:38 -07:00
										 |  |  | .. class:: Text
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    ``Text`` is an alias for ``str``. It is provided to supply a forward
 | 
					
						
							|  |  |  |    compatible path for Python 2 code: in Python 2, ``Text`` is an alias for
 | 
					
						
							|  |  |  |    ``unicode``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Use ``Text`` to indicate that a value must contain a unicode string in
 | 
					
						
							|  |  |  |    a manner that is compatible with both Python 2 and Python 3::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        def add_unicode_checkmark(text: Text) -> Text:
 | 
					
						
							|  |  |  |            return text + u' \u2713'
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-26 23:23:02 +01:00
										 |  |  |    .. versionadded:: 3.5.2
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | .. class:: io
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  |    Wrapper namespace for I/O stream types.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-12-13 09:39:55 +01:00
										 |  |  |    This defines the generic type ``IO[AnyStr]`` and subclasses ``TextIO``
 | 
					
						
							|  |  |  |    and ``BinaryIO``, deriving from ``IO[str]`` and ``IO[bytes]``,
 | 
					
						
							|  |  |  |    respectively. These represent the types of I/O streams such as returned by
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  |    :func:`open`.
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-08 09:09:14 -07:00
										 |  |  |    These types are also accessible directly as ``typing.IO``,
 | 
					
						
							|  |  |  |    ``typing.TextIO``, and ``typing.BinaryIO``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | .. class:: re
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-10 10:52:11 -07:00
										 |  |  |    Wrapper namespace for regular expression matching types.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    This defines the type aliases ``Pattern`` and ``Match`` which
 | 
					
						
							|  |  |  |    correspond to the return types from :func:`re.compile` and
 | 
					
						
							|  |  |  |    :func:`re.match`.  These types (and the corresponding functions)
 | 
					
						
							|  |  |  |    are generic in ``AnyStr`` and can be made specific by writing
 | 
					
						
							|  |  |  |    ``Pattern[str]``, ``Pattern[bytes]``, ``Match[str]``, or
 | 
					
						
							|  |  |  |    ``Match[bytes]``.
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-08 09:09:14 -07:00
										 |  |  |    These types are also accessible directly as ``typing.Pattern``
 | 
					
						
							|  |  |  |    and ``typing.Match``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-25 09:53:11 -07:00
										 |  |  | .. class:: NamedTuple
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |    Typed version of namedtuple.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Usage::
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-25 09:53:11 -07:00
										 |  |  |        class Employee(NamedTuple):
 | 
					
						
							|  |  |  |            name: str
 | 
					
						
							|  |  |  |            id: int
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |    This is equivalent to::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        Employee = collections.namedtuple('Employee', ['name', 'id'])
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-28 20:16:40 -08:00
										 |  |  |    To give a field a default value, you can assign to it in the class body::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       class Employee(NamedTuple):
 | 
					
						
							|  |  |  |           name: str
 | 
					
						
							|  |  |  |           id: int = 3
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       employee = Employee('Guido')
 | 
					
						
							|  |  |  |       assert employee.id == 3
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Fields with a default value must come after any fields without a default.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    The resulting class has two extra attributes: ``_field_types``,
 | 
					
						
							| 
									
										
										
										
											2017-04-08 09:09:14 -07:00
										 |  |  |    giving a dict mapping field names to types, and ``_field_defaults``, a dict
 | 
					
						
							| 
									
										
										
										
											2017-01-28 20:16:40 -08:00
										 |  |  |    mapping field names to default values.  (The field names are in the
 | 
					
						
							|  |  |  |    ``_fields`` attribute, which is part of the namedtuple API.)
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-08 09:09:14 -07:00
										 |  |  |    ``NamedTuple`` subclasses can also have docstrings and methods::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       class Employee(NamedTuple):
 | 
					
						
							|  |  |  |           """Represents an employee."""
 | 
					
						
							|  |  |  |           name: str
 | 
					
						
							|  |  |  |           id: int = 3
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           def __repr__(self) -> str:
 | 
					
						
							|  |  |  |               return f'<Employee {self.name}, id={self.id}>'
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-25 09:53:11 -07:00
										 |  |  |    Backward-compatible usage::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        Employee = NamedTuple('Employee', [('name', str), ('id', int)])
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. versionchanged:: 3.6
 | 
					
						
							|  |  |  |       Added support for :pep:`526` variable annotation syntax.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-01-28 20:16:40 -08:00
										 |  |  |    .. versionchanged:: 3.6.1
 | 
					
						
							| 
									
										
										
										
											2017-04-08 09:09:14 -07:00
										 |  |  |       Added support for default values, methods, and docstrings.
 | 
					
						
							| 
									
										
										
										
											2017-01-28 20:16:40 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-10 18:54:14 -07:00
										 |  |  | .. function:: NewType(typ)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    A helper function to indicate a distinct types to a typechecker,
 | 
					
						
							|  |  |  |    see :ref:`distinct`. At runtime it returns a function that returns
 | 
					
						
							|  |  |  |    its argument. Usage::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       UserId = NewType('UserId', int)
 | 
					
						
							|  |  |  |       first_user = UserId(1)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-26 23:23:02 +01:00
										 |  |  |    .. versionadded:: 3.5.2
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | .. function:: cast(typ, val)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Cast a value to a type.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    This returns the value unchanged.  To the type checker this
 | 
					
						
							|  |  |  |    signals that the return value has the designated type, but at
 | 
					
						
							|  |  |  |    runtime we intentionally don't check anything (we want this
 | 
					
						
							|  |  |  |    to be as fast as possible).
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-25 20:10:07 +03:00
										 |  |  | .. function:: get_type_hints(obj[, globals[, locals]])
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-11 15:54:04 -08:00
										 |  |  |    Return a dictionary containing type hints for a function, method, module
 | 
					
						
							|  |  |  |    or class object.
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-11 15:54:04 -08:00
										 |  |  |    This is often the same as ``obj.__annotations__``. In addition,
 | 
					
						
							|  |  |  |    forward references encoded as string literals are handled by evaluating
 | 
					
						
							|  |  |  |    them in ``globals`` and ``locals`` namespaces. If necessary,
 | 
					
						
							|  |  |  |    ``Optional[t]`` is added for function and method annotations if a default
 | 
					
						
							|  |  |  |    value equal to ``None`` is set. For a class ``C``, return
 | 
					
						
							|  |  |  |    a dictionary constructed by merging all the ``__annotations__`` along
 | 
					
						
							|  |  |  |    ``C.__mro__`` in reverse order.
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-10 18:54:14 -07:00
										 |  |  | .. decorator:: overload
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    The ``@overload`` decorator allows describing functions and methods
 | 
					
						
							|  |  |  |    that support multiple different combinations of argument types. A series
 | 
					
						
							|  |  |  |    of ``@overload``-decorated definitions must be followed by exactly one
 | 
					
						
							|  |  |  |    non-``@overload``-decorated definition (for the same function/method).
 | 
					
						
							|  |  |  |    The ``@overload``-decorated definitions are for the benefit of the
 | 
					
						
							|  |  |  |    type checker only, since they will be overwritten by the
 | 
					
						
							|  |  |  |    non-``@overload``-decorated definition, while the latter is used at
 | 
					
						
							|  |  |  |    runtime but should be ignored by a type checker.  At runtime, calling
 | 
					
						
							|  |  |  |    a ``@overload``-decorated function directly will raise
 | 
					
						
							|  |  |  |    ``NotImplementedError``. An example of overload that gives a more
 | 
					
						
							|  |  |  |    precise type than can be expressed using a union or a type variable::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       @overload
 | 
					
						
							|  |  |  |       def process(response: None) -> None:
 | 
					
						
							|  |  |  |           ...
 | 
					
						
							|  |  |  |       @overload
 | 
					
						
							|  |  |  |       def process(response: int) -> Tuple[int, str]:
 | 
					
						
							|  |  |  |           ...
 | 
					
						
							|  |  |  |       @overload
 | 
					
						
							|  |  |  |       def process(response: bytes) -> str:
 | 
					
						
							|  |  |  |           ...
 | 
					
						
							|  |  |  |       def process(response):
 | 
					
						
							|  |  |  |           <actual implementation>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    See :pep:`484` for details and comparison with other typing semantics.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-12 12:28:55 -04:00
										 |  |  | .. decorator:: no_type_check
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |    Decorator to indicate that annotations are not type hints.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-12 12:28:55 -04:00
										 |  |  |    This works as class or function :term:`decorator`.  With a class, it
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  |    applies recursively to all methods defined in that class (but not
 | 
					
						
							|  |  |  |    to methods defined in its superclasses or subclasses).
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    This mutates the function(s) in place.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-10-12 12:28:55 -04:00
										 |  |  | .. decorator:: no_type_check_decorator
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-09-10 21:55:50 +03:00
										 |  |  |    Decorator to give another decorator the :func:`no_type_check` effect.
 | 
					
						
							| 
									
										
										
										
											2015-08-03 22:35:46 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |    This wraps the decorator with something that wraps the decorated
 | 
					
						
							| 
									
										
										
										
											2015-09-10 21:55:50 +03:00
										 |  |  |    function in :func:`no_type_check`.
 | 
					
						
							| 
									
										
										
										
											2016-09-10 18:54:14 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-08 20:06:56 -07:00
										 |  |  | .. data:: Any
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Special type indicating an unconstrained type.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    * Every type is compatible with :data:`Any`.
 | 
					
						
							|  |  |  |    * :data:`Any` is compatible with every type.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-24 21:33:55 -07:00
										 |  |  | .. data:: NoReturn
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Special type indicating that a function never returns.
 | 
					
						
							|  |  |  |    For example::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       from typing import NoReturn
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       def stop() -> NoReturn:
 | 
					
						
							|  |  |  |           raise RuntimeError('no way')
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.6.5
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-08 20:06:56 -07:00
										 |  |  | .. data:: Union
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Union type; ``Union[X, Y]`` means either X or Y.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    To define a union, use e.g. ``Union[int, str]``.  Details:
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    * The arguments must be types and there must be at least one.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    * Unions of unions are flattened, e.g.::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        Union[Union[int, str], float] == Union[int, str, float]
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    * Unions of a single argument vanish, e.g.::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        Union[int] == int  # The constructor actually returns int
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    * Redundant arguments are skipped, e.g.::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        Union[int, str, int] == Union[int, str]
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    * When comparing unions, the argument order is ignored, e.g.::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        Union[int, str] == Union[str, int]
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    * You cannot subclass or instantiate a union.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    * You cannot write ``Union[X][Y]``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    * You can use ``Optional[X]`` as a shorthand for ``Union[X, None]``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-18 16:00:38 -07:00
										 |  |  |    .. versionchanged:: 3.7
 | 
					
						
							|  |  |  |       Don't remove explicit subclasses from unions at runtime.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-08 20:06:56 -07:00
										 |  |  | .. data:: Optional
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Optional type.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    ``Optional[X]`` is equivalent to ``Union[X, None]``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Note that this is not the same concept as an optional argument,
 | 
					
						
							|  |  |  |    which is one that has a default.  An optional argument with a
 | 
					
						
							|  |  |  |    default needn't use the ``Optional`` qualifier on its type
 | 
					
						
							|  |  |  |    annotation (although it is inferred if the default is ``None``).
 | 
					
						
							|  |  |  |    A mandatory argument may still have an ``Optional`` type if an
 | 
					
						
							|  |  |  |    explicit value of ``None`` is allowed.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. data:: Tuple
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-11 15:54:04 -08:00
										 |  |  |    Tuple type; ``Tuple[X, Y]`` is the type of a tuple of two items
 | 
					
						
							|  |  |  |    with the first item of type X and the second of type Y.
 | 
					
						
							| 
									
										
										
										
											2016-10-08 20:06:56 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-11 15:54:04 -08:00
										 |  |  |    Example: ``Tuple[T1, T2]`` is a tuple of two elements corresponding
 | 
					
						
							|  |  |  |    to type variables T1 and T2.  ``Tuple[int, float, str]`` is a tuple
 | 
					
						
							|  |  |  |    of an int, a float and a string.
 | 
					
						
							| 
									
										
										
										
											2016-10-08 20:06:56 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-11 15:54:04 -08:00
										 |  |  |    To specify a variable-length tuple of homogeneous type,
 | 
					
						
							|  |  |  |    use literal ellipsis, e.g. ``Tuple[int, ...]``. A plain :data:`Tuple`
 | 
					
						
							|  |  |  |    is equivalent to ``Tuple[Any, ...]``, and in turn to :class:`tuple`.
 | 
					
						
							| 
									
										
										
										
											2016-10-08 20:06:56 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | .. data:: Callable
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Callable type; ``Callable[[int], str]`` is a function of (int) -> str.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    The subscription syntax must always be used with exactly two
 | 
					
						
							|  |  |  |    values: the argument list and the return type.  The argument list
 | 
					
						
							| 
									
										
										
										
											2016-11-11 15:54:04 -08:00
										 |  |  |    must be a list of types or an ellipsis; the return type must be
 | 
					
						
							|  |  |  |    a single type.
 | 
					
						
							| 
									
										
										
										
											2016-10-08 20:06:56 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |    There is no syntax to indicate optional or keyword arguments;
 | 
					
						
							|  |  |  |    such function types are rarely used as callback types.
 | 
					
						
							|  |  |  |    ``Callable[..., ReturnType]`` (literal ellipsis) can be used to
 | 
					
						
							|  |  |  |    type hint a callable taking any number of arguments and returning
 | 
					
						
							|  |  |  |    ``ReturnType``.  A plain :data:`Callable` is equivalent to
 | 
					
						
							|  |  |  |    ``Callable[..., Any]``, and in turn to
 | 
					
						
							|  |  |  |    :class:`collections.abc.Callable`.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-10 18:54:14 -07:00
										 |  |  | .. data:: ClassVar
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Special type construct to mark class variables.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    As introduced in :pep:`526`, a variable annotation wrapped in ClassVar
 | 
					
						
							|  |  |  |    indicates that a given attribute is intended to be used as a class variable
 | 
					
						
							|  |  |  |    and should not be set on instances of that class. Usage::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       class Starship:
 | 
					
						
							|  |  |  |           stats: ClassVar[Dict[str, int]] = {} # class variable
 | 
					
						
							|  |  |  |           damage: int = 10                     # instance variable
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-08 20:06:56 -07:00
										 |  |  |    :data:`ClassVar` accepts only types and cannot be further subscribed.
 | 
					
						
							| 
									
										
										
										
											2016-09-10 18:54:14 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-08 20:06:56 -07:00
										 |  |  |    :data:`ClassVar` is not a class itself, and should not
 | 
					
						
							|  |  |  |    be used with :func:`isinstance` or :func:`issubclass`.
 | 
					
						
							| 
									
										
										
										
											2017-04-08 09:09:14 -07:00
										 |  |  |    :data:`ClassVar` does not change Python runtime behavior, but
 | 
					
						
							|  |  |  |    it can be used by third-party type checkers. For example, a type checker
 | 
					
						
							|  |  |  |    might flag the following code as an error::
 | 
					
						
							| 
									
										
										
										
											2016-09-10 18:54:14 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |       enterprise_d = Starship(3000)
 | 
					
						
							|  |  |  |       enterprise_d.stats = {} # Error, setting class variable on instance
 | 
					
						
							|  |  |  |       Starship.stats = {}     # This is OK
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-10-08 20:06:56 -07:00
										 |  |  |    .. versionadded:: 3.5.3
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | .. data:: AnyStr
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    ``AnyStr`` is a type variable defined as
 | 
					
						
							|  |  |  |    ``AnyStr = TypeVar('AnyStr', str, bytes)``.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    It is meant to be used for functions that may accept any kind of string
 | 
					
						
							|  |  |  |    without allowing different kinds of strings to mix. For example::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       def concat(a: AnyStr, b: AnyStr) -> AnyStr:
 | 
					
						
							|  |  |  |           return a + b
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       concat(u"foo", u"bar")  # Ok, output has type 'unicode'
 | 
					
						
							|  |  |  |       concat(b"foo", b"bar")  # Ok, output has type 'bytes'
 | 
					
						
							|  |  |  |       concat(u"foo", b"bar")  # Error, cannot mix unicode and bytes
 | 
					
						
							| 
									
										
										
										
											2016-09-10 18:54:14 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | .. data:: TYPE_CHECKING
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    A special constant that is assumed to be ``True`` by 3rd party static
 | 
					
						
							|  |  |  |    type checkers. It is ``False`` at runtime. Usage::
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if TYPE_CHECKING:
 | 
					
						
							|  |  |  |           import expensive_mod
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-26 06:49:45 -04:00
										 |  |  |       def fun(arg: 'expensive_mod.SomeType') -> None:
 | 
					
						
							|  |  |  |           local_var: expensive_mod.AnotherType = other_fun()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |    Note that the first type annotation must be enclosed in quotes, making it a
 | 
					
						
							|  |  |  |    "forward reference", to hide the ``expensive_mod`` reference from the
 | 
					
						
							|  |  |  |    interpreter runtime.  Type annotations for local variables are not
 | 
					
						
							|  |  |  |    evaluated, so the second annotation does not need to be enclosed in quotes.
 | 
					
						
							| 
									
										
										
										
											2017-11-26 23:23:02 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |    .. versionadded:: 3.5.2
 |