typed_ast is a Python 3 package that provides a Python 2.7 and Python 3
parser similar to the standard
ast library. Unlike
ast, the parsers in
typed_ast include PEP 484 type
comments and are independent of the version of Python under which they are run.
typed_ast parsers produce the standard Python AST (plus type comments),
and are both fast and correct, as they are based on the CPython 2.7 and 3.7
typed_ast runs on CPython 3.5-3.8 on Linux, OS X and Windows.
This project is a (mostly) drop-in replacement for the builtin
ast module. It is
intended to be bug-for-bug compatible and behave identically, except for the
presence of a few additional fields on the returned classes and a few
additional optional arguments to the
parse call. Therefore,
not accept any bugfixes for bugs in
ast -- they should be fixed upstream
instead. To avoid feature bloat, any new features for
typed_ast should have
the potential to be broadly useful and not be built just for one niche usecase
or in a manner such that only one project can use them.
For the purposes of consuming syntax trees, this should be a drop-in replacement. It is not a drop-in replacement for users that wish to create or transform ASTs, as a number of syntax tree classes have additional fields that must be populated when constructing them.
Due to reliance on certain C APIs, this library does not build on and there are no plans to support PyPy.
typed_ast will not be updated to support parsing Python 3.8 and
newer. Instead, it is recommended to use the stdlib
there, which has been augmented to support extracting type comments
and has limited support for parsing older versions of Python 3.
ast3 parser produces the AST from a recent version of Python 3
(currently Python 3.6). When new versions of Python 3 are released, it will be
updated to match any changes in their AST. (For rationale and technical
details, see here.) The AST it currently produces is described in
ast3/Parser/Python.asdl. If you wish to limit
parsing to older versions of Python 3,
ast3 can be configured to to give a
SyntaxError for new syntax features introduced beyond a given Python version.
For more information, see the module docstring in
ast27 parser tracks the standard Python 2.7 AST, which is expected to
never receive further updates. The AST it produces is described in
ast27/Parser/Python.asdl. For more information,
see the module docstring in typed_ast/ast27.py.
typed_ast also provides a
conversions module which converts
ast3 ASTs. This functionality is somewhat experimental, however. For
more information, see the
py2to3 docstring in
Note: as these parsers consider type comments part of the grammar, incorrectly placed type comments are considered syntax errors.
typed_ast for new major Python releases, see
To make a new
typed_ast release, see