Legacy type syntax for docstrings
Last modified: 01 October 2021PyCharm supports legacy approach to specifying types in Python using docstrings. In doing so, the supported formats are:
To choose the desired docstring format, use the Python Integrated Tools page of the Settings/Preferences dialog.
Type syntax in Python docstrings is not defined by any standard. Thus, PyCharm suggests the following notation:
Syntax | Description |
---|---|
| Class Foo visible in the current scope |
| Class Bar from x.y module |
| Foo or Bar |
| Tuple of Foo and Bar |
| List of Foo elements |
| Dict from Foo to Bar |
| Generic type (T-Z are reserved for generics) |
| Generic type with upper bound Foo |
| Foo parameterized with T |
| Function of Foo and Bar that returns Baz |
| List of dicts from str to datetime (nested arguments) |
Specifying types of local variables
Consider adding information about the expected type of a local variable using :type
or @type
docstrings:
data:image/s3,"s3://crabby-images/9badc/9badca5e864d74d6804203820b0c14c1744d94ba" alt="Type hinting for local vars Type hinting for local vars"
It is also possible to use isinstance
to define the expected local variable type:
data:image/s3,"s3://crabby-images/19417/194170e94ee7cda409434858c926d213c259a3e6" alt="Type hinting for local vars Type hinting for local vars"
Specifying types of fields
You can use type hinting to specify the expected type of fields:
data:image/s3,"s3://crabby-images/db5b4/db5b4f1c9337e3eecd36b39b81328fae603c0eb1" alt="Type hinting for fields Type hinting for fields"
Alternatively, you can specify types of fields in the docstring of a class:
data:image/s3,"s3://crabby-images/49a9c/49a9c92b39427b2ec2edb24cb61cdf0380c6cc79" alt="Type hinting for class attributes Type hinting for class attributes"
Specifying return types
Use docstrings :rtype
or @rtype
to specify the expected return type:
data:image/s3,"s3://crabby-images/95995/95995d387853e607bea2020f3fec55b821a39969" alt="py_type_hinting_return2 py_type_hinting_return2"
:rtype: collections.Iterable[int] # return type
: 'items' is of typegenerator
orcollections.Iterable
, 'a' is of typeint
, see the following code:def my_iter(): global i for i in range(10): yield i items = my_iter() for a in items: print a
:rtype: list[int] for my_iter # return type: 'a' is of type
int
, see the following code:def my_iter(): for i in range(10): yield i for a in my_iter(): print a
Specifying parameter types
Consider adding information about the expected parameter type. This information is specified using docstrings. You can use different docstrings depending on the selected docstring format, for example, :type
, @type
, or Args
. Use project settings to alter the docstring format (File | Settings/Preferences | Tools | Python Integrated Tools).
data:image/s3,"s3://crabby-images/e91c3/e91c370c2285e3133bd41803260ea8831bfd659f" alt="Using docstrings to define parameter type(:type) Using docstrings to define parameter type(:type)"
data:image/s3,"s3://crabby-images/057e7/057e794583ebdb4040e733fbdd89c45c0a057678" alt="Using docstrings to define parameter type(Args) Using docstrings to define parameter type(Args)"
Thanks for your feedback!