ast — Árboles de sintaxis abstracta¶
Código fuente: Lib/ast.py
El módulo ast ayuda a las aplicaciones de Python a procesar árboles de la gramática de sintaxis abstracta de Python. La sintaxis abstracta en sí misma puede cambiar con cada versión de Python; Este módulo ayuda a descubrir mediante programación cómo se ve la gramática actual.
Se puede generar un árbol de sintaxis abstracta pasando ast.PyCF_ONLY_AST como un indicador de la función incorporada compile(), o usando el ayudante parse() provisto en este módulo. El resultado será un árbol de objetos cuyas clases todas heredan de ast.AST. Se puede compilar un árbol de sintaxis abstracta en un objeto de código Python utilizando la función incorporada compile().
Gramática abstracta¶
La gramática abstracta se define actualmente de la siguiente manera:
-- ASDL's 4 builtin types are:
-- identifier, int, string, constant
module Python
{
    mod = Module(stmt* body, type_ignore* type_ignores)
        | Interactive(stmt* body)
        | Expression(expr body)
        | FunctionType(expr* argtypes, expr returns)
    stmt = FunctionDef(identifier name, arguments args,
                       stmt* body, expr* decorator_list, expr? returns,
                       string? type_comment)
          | AsyncFunctionDef(identifier name, arguments args,
                             stmt* body, expr* decorator_list, expr? returns,
                             string? type_comment)
          | ClassDef(identifier name,
             expr* bases,
             keyword* keywords,
             stmt* body,
             expr* decorator_list)
          | Return(expr? value)
          | Delete(expr* targets)
          | Assign(expr* targets, expr value, string? type_comment)
          | AugAssign(expr target, operator op, expr value)
          -- 'simple' indicates that we annotate simple name without parens
          | AnnAssign(expr target, expr annotation, expr? value, int simple)
          -- use 'orelse' because else is a keyword in target languages
          | For(expr target, expr iter, stmt* body, stmt* orelse, string? type_comment)
          | AsyncFor(expr target, expr iter, stmt* body, stmt* orelse, string? type_comment)
          | While(expr test, stmt* body, stmt* orelse)
          | If(expr test, stmt* body, stmt* orelse)
          | With(withitem* items, stmt* body, string? type_comment)
          | AsyncWith(withitem* items, stmt* body, string? type_comment)
          | Match(expr subject, match_case* cases)
          | Raise(expr? exc, expr? cause)
          | Try(stmt* body, excepthandler* handlers, stmt* orelse, stmt* finalbody)
          | Assert(expr test, expr? msg)
          | Import(alias* names)
          | ImportFrom(identifier? module, alias* names, int? level)
          | Global(identifier* names)
          | Nonlocal(identifier* names)
          | Expr(expr value)
          | Pass | Break | Continue
          -- col_offset is the byte offset in the utf8 string the parser uses
          attributes (int lineno, int col_offset, int? end_lineno, int? end_col_offset)
          -- BoolOp() can use left & right?
    expr = BoolOp(boolop op, expr* values)
         | NamedExpr(expr target, expr value)
         | BinOp(expr left, operator op, expr right)
         | UnaryOp(unaryop op, expr operand)
         | Lambda(arguments args, expr body)
         | IfExp(expr test, expr body, expr orelse)
         | Dict(expr* keys, expr* values)
         | Set(expr* elts)
         | ListComp(expr elt, comprehension* generators)
         | SetComp(expr elt, comprehension* generators)
         | DictComp(expr key, expr value, comprehension* generators)
         | GeneratorExp(expr elt, comprehension* generators)
         -- the grammar constrains where yield expressions can occur
         | Await(expr value)
         | Yield(expr? value)
         | YieldFrom(expr value)
         -- need sequences for compare to distinguish between
         -- x < 4 < 3 and (x < 4) < 3
         | Compare(expr left, cmpop* ops, expr* comparators)
         | Call(expr func, expr* args, keyword* keywords)
         | FormattedValue(expr value, int conversion, expr? format_spec)
         | JoinedStr(expr* values)
         | Constant(constant value, string? kind)
         -- the following expression can appear in assignment context
         | Attribute(expr value, identifier attr, expr_context ctx)
         | Subscript(expr value, expr slice, expr_context ctx)
         | Starred(expr value, expr_context ctx)
         | Name(identifier id, expr_context ctx)
         | List(expr* elts, expr_context ctx)
         | Tuple(expr* elts, expr_context ctx)
         -- can appear only in Subscript
         | Slice(expr? lower, expr? upper, expr? step)
          -- col_offset is the byte offset in the utf8 string the parser uses
          attributes (int lineno, int col_offset, int? end_lineno, int? end_col_offset)
    expr_context = Load | Store | Del
    boolop = And | Or
    operator = Add | Sub | Mult | MatMult | Div | Mod | Pow | LShift
                 | RShift | BitOr | BitXor | BitAnd | FloorDiv
    unaryop = Invert | Not | UAdd | USub
    cmpop = Eq | NotEq | Lt | LtE | Gt | GtE | Is | IsNot | In | NotIn
    comprehension = (expr target, expr iter, expr* ifs, int is_async)
    excepthandler = ExceptHandler(expr? type, identifier? name, stmt* body)
                    attributes (int lineno, int col_offset, int? end_lineno, int? end_col_offset)
    arguments = (arg* posonlyargs, arg* args, arg? vararg, arg* kwonlyargs,
                 expr* kw_defaults, arg? kwarg, expr* defaults)
    arg = (identifier arg, expr? annotation, string? type_comment)
           attributes (int lineno, int col_offset, int? end_lineno, int? end_col_offset)
    -- keyword arguments supplied to call (NULL identifier for **kwargs)
    keyword = (identifier? arg, expr value)
               attributes (int lineno, int col_offset, int? end_lineno, int? end_col_offset)
    -- import name with optional 'as' alias.
    alias = (identifier name, identifier? asname)
             attributes (int lineno, int col_offset, int? end_lineno, int? end_col_offset)
    withitem = (expr context_expr, expr? optional_vars)
    match_case = (pattern pattern, expr? guard, stmt* body)
    pattern = MatchValue(expr value)
            | MatchSingleton(constant value)
            | MatchSequence(pattern* patterns)
            | MatchMapping(expr* keys, pattern* patterns, identifier? rest)
            | MatchClass(expr cls, pattern* patterns, identifier* kwd_attrs, pattern* kwd_patterns)
            | MatchStar(identifier? name)
            -- The optional "rest" MatchMapping parameter handles capturing extra mapping keys
            | MatchAs(pattern? pattern, identifier? name)
            | MatchOr(pattern* patterns)
             attributes (int lineno, int col_offset, int end_lineno, int end_col_offset)
    type_ignore = TypeIgnore(int lineno, string tag)
}
Clases Nodo¶
- 
class 
ast.AST¶ This is the base of all AST node classes. The actual node classes are derived from the
Parser/Python.asdlfile, which is reproduced above. They are defined in the_astC module and re-exported inast.Hay una clase definida para cada símbolo del lado izquierdo en la gramática abstracta (por ejemplo,
ast.stmtoast.expr). Además, hay una clase definida para cada constructor en el lado derecho; estas clases heredan de las clases para los árboles del lado izquierdo. Por ejemplo,ast.BinOphereda deast.expr. Para las reglas de producción con alternativas (también conocidas como «sumas»), la clase del lado izquierdo es abstracta: solo se crean instancias de nodos de constructor específicos.- 
_fields¶ Cada clase concreta tiene un atributo
_fieldsque proporciona los nombres de todos los nodos secundarios.Cada instancia de una clase concreta tiene un atributo para cada nodo secundario, del tipo definido en la gramática. Por ejemplo, las instancias
ast.BinOptienen un atributoleftde tipoast.expr.Si estos atributos están marcados como opcionales en la gramática (usando un signo de interrogación), el valor podría ser
None. Si los atributos pueden tener cero o más valores (marcados con un asterisco), los valores se representan como listas de Python. Todos los atributos posibles deben estar presentes y tener valores válidos al compilar un AST concompile().
- 
lineno¶ - 
col_offset¶ - 
end_lineno¶ - 
end_col_offset¶ Las instancias de las subclases
ast.expryast.stmttienen atributoslineno,col_offset,lineno, ycol_offset.linenoyend_linenoson los números de la primera y última línea del intervalo de texto de origen (1 indexado, por lo que la primera línea es la línea 1), ycol_offsetyend_col_offsetson las correspondientes compensaciones de bytes UTF-8 del primer y último token que generó el nodo. El desplazamiento UTF-8 se registra porque el analizador utiliza UTF-8 internamente.Tenga en cuenta que el compilador no requiere las posiciones finales y, por lo tanto, son opcionales. El desplazamiento final es después del último símbolo, por ejemplo, uno puede obtener el segmento fuente de un nodo de expresión de una línea usando
source_line[node.col_offset: node.end_col_offset].
El constructor de una clase
ast.Tanaliza sus argumentos de la siguiente manera:Si hay argumentos posicionales, debe haber tantos como elementos en
T._fields; serán asignados como atributos de estos nombres.Si hay argumentos de palabras clave, establecerán los atributos de los mismos nombres a los valores dados.
Por ejemplo, para crear y completar un nodo
ast.UnaryOp, puede usarnode = ast.UnaryOp() node.op = ast.USub() node.operand = ast.Constant() node.operand.value = 5 node.operand.lineno = 0 node.operand.col_offset = 0 node.lineno = 0 node.col_offset = 0
o la más compacta
node = ast.UnaryOp(ast.USub(), ast.Constant(5, lineno=0, col_offset=0), lineno=0, col_offset=0)
- 
 
Distinto en la versión 3.8: La clase ast.Constant ahora se usa para todas las constantes.
Distinto en la versión 3.9: Los índices simples se representan por su valor, los segmentos extendidos se representan como tuplas.
Obsoleto desde la versión 3.8: Las clases antiguas ast. Num, ast. Str, ast. Bytes, ast. NameConstant y ast.Ellipsis todavía están disponibles, pero se eliminarán en futuras versiones de Python. Mientras tanto, crear sus instancias retornará una instancia de una clase diferente.
Obsoleto desde la versión 3.9: Las clases antiguas ast.Index y ast.ExtSlice todavía están disponibles, pero se eliminarán en futuras versiones de Python. Mientras tanto, crear sus instancias retornará una instancia de una clase diferente.
Nota
Las descripciones de las clases de nodo específicas mostradas aquí fueron adaptadas inicialmente del fantástico proyecto Green Tree Snakes y todos sus contribuidores.
Literales¶
- 
class 
ast.Constant(value)¶ Un valor constante. El atributo
valuedel literalConstantcontiene el objeto de Python que este representa. Los valores representados pueden ser de tipos simple como un número, una cadena de caracteres oNone; pero también pueden ser de tipos de contenedores inmutables (tuplas yfrozensets) si todos sus elementos son constantes.>>> print(ast.dump(ast.parse('123', mode='eval'), indent=4)) Expression( body=Constant(value=123))
- 
class 
ast.FormattedValue(value, conversion, format_spec)¶ Nodo que representa un único campo de formato en una
f-string. Si la cadena de caracteres contiene un único campo de formato y nada más, el nodo puede estar aislado de otra manera aparece enJoinedStr.valuees cualquier nodo de expresión (como un literal, una variable o una llamada a función).conversiones un entero:-1: sin formato
115:
!sformato de cadena de caracteres114:
!rformato repr97:
!aformato ascii
format_speces un nodoJoinedStrque representa el formato del valor, oNonesi no se ha especificado un formato. Ambos,conversionyformat_spec, pueden estar especificados al mismo tiempo.
- 
class 
ast.JoinedStr(values)¶ Un f-string que comprende una serie de nodos
FormattedValueyConstant.>>> print(ast.dump(ast.parse('f"sin({a}) is {sin(a):.3}"', mode='eval'), indent=4)) Expression( body=JoinedStr( values=[ Constant(value='sin('), FormattedValue( value=Name(id='a', ctx=Load()), conversion=-1), Constant(value=') is '), FormattedValue( value=Call( func=Name(id='sin', ctx=Load()), args=[ Name(id='a', ctx=Load())], keywords=[]), conversion=-1, format_spec=JoinedStr( values=[ Constant(value='.3')]))]))
- 
class 
ast.List(elts, ctx)¶ - 
class 
ast.Tuple(elts, ctx)¶ Una lista o tupla.
eltscontiene una lista de nodos que representa a los elementos.ctxesStoresi el contenedor es un objetivo de asignación (por ejemplo(x,y)=something), yLoaden cualquier otro caso.>>> print(ast.dump(ast.parse('[1, 2, 3]', mode='eval'), indent=4)) Expression( body=List( elts=[ Constant(value=1), Constant(value=2), Constant(value=3)], ctx=Load())) >>> print(ast.dump(ast.parse('(1, 2, 3)', mode='eval'), indent=4)) Expression( body=Tuple( elts=[ Constant(value=1), Constant(value=2), Constant(value=3)], ctx=Load()))
- 
class 
ast.Set(elts)¶ Un set.
eltscontiene una lista de nodos que representa a un set de elementos.>>> print(ast.dump(ast.parse('{1, 2, 3}', mode='eval'), indent=4)) Expression( body=Set( elts=[ Constant(value=1), Constant(value=2), Constant(value=3)]))
- 
class 
ast.Dict(keys, values)¶ Un diccionario.
keysyvaluescontienen listas de nodos que representan las claves y los valores respectivamente en el orden correspondiente (el orden que retornaríadictionary.keys()ydictionary.values()).Cuando se desempaqueta un diccionario utilizando literales de diccionario, la expresión a ser expandida va en la lista
values, conNoneen la posición correspondiente enkeys.>>> print(ast.dump(ast.parse('{"a":1, **d}', mode='eval'), indent=4)) Expression( body=Dict( keys=[ Constant(value='a'), None], values=[ Constant(value=1), Name(id='d', ctx=Load())]))
Variables¶
- 
class 
ast.Name(id, ctx)¶ Un nombre de variable.
idcontiene el nombre de una cadena de caracteres yctxes uno de los siguientes tipos.
- 
class 
ast.Load¶ - 
class 
ast.Store¶ - 
class 
ast.Del¶ Referencias a variables que pueden ser usadas para cargar el valor de una variable, asignar un nuevo valor o borrarlo. Las referencias a variables reciben un contexto para distinguir entre estos casos.
>>> print(ast.dump(ast.parse('a'), indent=4)) Module( body=[ Expr( value=Name(id='a', ctx=Load()))], type_ignores=[]) >>> print(ast.dump(ast.parse('a = 1'), indent=4)) Module( body=[ Assign( targets=[ Name(id='a', ctx=Store())], value=Constant(value=1))], type_ignores=[]) >>> print(ast.dump(ast.parse('del a'), indent=4)) Module( body=[ Delete( targets=[ Name(id='a', ctx=Del())])], type_ignores=[])
- 
class 
ast.Starred(value, ctx)¶ Una referencia a variable
*var.valuecontiene la variable, típicamente un nodoName. Este tipo puede ser usado cuando se construye un nodoCallcon*args.>>> print(ast.dump(ast.parse('a, *b = it'), indent=4)) Module( body=[ Assign( targets=[ Tuple( elts=[ Name(id='a', ctx=Store()), Starred( value=Name(id='b', ctx=Store()), ctx=Store())], ctx=Store())], value=Name(id='it', ctx=Load()))], type_ignores=[])
Expresiones¶
- 
class 
ast.Expr(value)¶ Cuando una expresión, como un llamado a función, aparece como una declaración por sí misma sin que su valor de retorno se use o se almacene, está dentro de este contenedor.
valuecontiene uno de los otros nodos en esta sección, un nodoConstant,Name,Lambda,YieldoYieldFrom.>>> print(ast.dump(ast.parse('-a'), indent=4)) Module( body=[ Expr( value=UnaryOp( op=USub(), operand=Name(id='a', ctx=Load())))], type_ignores=[])
- 
class 
ast.UnaryOp(op, operand)¶ Una operación unaria.
opes el operador yoperandes cualquier nodo de expresión.
- 
class 
ast.UAdd¶ - 
class 
ast.USub¶ - 
class 
ast.Not¶ - 
class 
ast.Invert¶ Tokens de operador unario.
Notes la palabra clavenot,Invertes el operador~.>>> print(ast.dump(ast.parse('not x', mode='eval'), indent=4)) Expression( body=UnaryOp( op=Not(), operand=Name(id='x', ctx=Load())))
- 
class 
ast.BinOp(left, op, right)¶ Una operación binaria (como la suma o división(.
opes el operador, yleftyrightson cualquier nodo de expresión.>>> print(ast.dump(ast.parse('x + y', mode='eval'), indent=4)) Expression( body=BinOp( left=Name(id='x', ctx=Load()), op=Add(), right=Name(id='y', ctx=Load())))
- 
class 
ast.Add¶ - 
class 
ast.Sub¶ - 
class 
ast.Mult¶ - 
class 
ast.Div¶ - 
class 
ast.FloorDiv¶ - 
class 
ast.Mod¶ - 
class 
ast.Pow¶ - 
class 
ast.LShift¶ - 
class 
ast.RShift¶ - 
class 
ast.BitOr¶ - 
class 
ast.BitXor¶ - 
class 
ast.BitAnd¶ - 
class 
ast.MatMult¶ Tokens de operador binario.
- 
class 
ast.BoolOp(op, values)¶ Una operación booleana, “or” y “and”.
opesOroAnd.valuesson los valores involucrados. Operaciones consecutivas con el mismo operador, comoa or b or c, colapsan en un nodo con varios valores.Esto no incluye
not, el cual es unUnaryOp.>>> print(ast.dump(ast.parse('x or y', mode='eval'), indent=4)) Expression( body=BoolOp( op=Or(), values=[ Name(id='x', ctx=Load()), Name(id='y', ctx=Load())]))
- 
class 
ast.Compare(left, ops, comparators)¶ Una comparación de dos o más valores.
leftes el primer valor en la comparación,opses la lista de operadores, ycomparatorses la lista de valores después de el primer elemento en la comparación.>>> print(ast.dump(ast.parse('1 <= a < 10', mode='eval'), indent=4)) Expression( body=Compare( left=Constant(value=1), ops=[ LtE(), Lt()], comparators=[ Name(id='a', ctx=Load()), Constant(value=10)]))
- 
class 
ast.Eq¶ - 
class 
ast.NotEq¶ - 
class 
ast.Lt¶ - 
class 
ast.LtE¶ - 
class 
ast.Gt¶ - 
class 
ast.GtE¶ - 
class 
ast.Is¶ - 
class 
ast.IsNot¶ - 
class 
ast.In¶ - 
class 
ast.NotIn¶ Tokens de operador de comparación.
- 
class 
ast.Call(func, args, keywords, starargs, kwargs)¶ Un llamado a función.
funcis la función, la cual suele ser un objetoNameoAttribute. De los argumentos:argscontiene una lista de argumentos pasados por posición.keywordscontiene una lista de objetoskeywordque representan argumentos pasados por nombre clave.
Cuando se crea un nodo
Call,argsykeywordsson requeridos pero pueden ser listas vacías.starargsykwargsson opcionales.>>> print(ast.dump(ast.parse('func(a, b=c, *d, **e)', mode='eval'), indent=4)) Expression( body=Call( func=Name(id='func', ctx=Load()), args=[ Name(id='a', ctx=Load()), Starred( value=Name(id='d', ctx=Load()), ctx=Load())], keywords=[ keyword( arg='b', value=Name(id='c', ctx=Load())), keyword( value=Name(id='e', ctx=Load()))]))
- 
class 
ast.keyword(arg, value)¶ Un argumento de palabra clave para una llamada de función o definición de clase.
arges una cadena de caracteres sin formato del nombre del parámetro,valores un nodo para pasar.
- 
class 
ast.IfExp(test, body, orelse)¶ Una expresión como
a if b else c. Cada campo contiene un único nodo, por lo que en el siguiente ejemplo, todos son nodosName.>>> print(ast.dump(ast.parse('a if b else c', mode='eval'), indent=4)) Expression( body=IfExp( test=Name(id='b', ctx=Load()), body=Name(id='a', ctx=Load()), orelse=Name(id='c', ctx=Load())))
- 
class 
ast.Attribute(value, attr, ctx)¶ Acceso a atributos, por ejemplo
d.keys.valuees un nodo, típicamente unName.attres una simple cadena de caracteres que da el nombre del atributo, yctxesLoad,StoreoDelde acuerdo a cómo se actúe sobre el atributo.>>> print(ast.dump(ast.parse('snake.colour', mode='eval'), indent=4)) Expression( body=Attribute( value=Name(id='snake', ctx=Load()), attr='colour', ctx=Load()))
- 
class 
ast.NamedExpr(target, value)¶ Una expresión con nombre. Este nodo AST es producido por el operador de expresiones de asignación (también conocido como el operador walrus). A diferencia del nodo
Assignen el cual el primer argumento puede ser varios nodos, en este casotargetyvaluedeben ser nodos únicos.>>> print(ast.dump(ast.parse('(x := 4)', mode='eval'), indent=4)) Expression( body=NamedExpr( target=Name(id='x', ctx=Store()), value=Constant(value=4)))
Subindexado¶
- 
class 
ast.Subscript(value, slice, ctx)¶ Un subíndice, como
l[1].valuees el objeto subindicado (usualmente una secuencia o mapeo).slicees un índice, un segmento o una clave. Este puede ser unaTupley contener unSlice.ctxesLoad,StoreorDelde acuerdo a la acción tomada con el subíndice.>>> print(ast.dump(ast.parse('l[1:2, 3]', mode='eval'), indent=4)) Expression( body=Subscript( value=Name(id='l', ctx=Load()), slice=Tuple( elts=[ Slice( lower=Constant(value=1), upper=Constant(value=2)), Constant(value=3)], ctx=Load()), ctx=Load()))
- 
class 
ast.Slice(lower, upper, step)¶ Una segmentación regular (en la forma
lower:upperolower:upper:step). Puede ocurrir solamente dentro del campo slice deSubscript, ya sea directamente o como un elemento deTuple.>>> print(ast.dump(ast.parse('l[1:2]', mode='eval'), indent=4)) Expression( body=Subscript( value=Name(id='l', ctx=Load()), slice=Slice( lower=Constant(value=1), upper=Constant(value=2)), ctx=Load()))
Comprensiones¶
- 
class 
ast.ListComp(elt, generators)¶ - 
class 
ast.SetComp(elt, generators)¶ - 
class 
ast.GeneratorExp(elt, generators)¶ - 
class 
ast.DictComp(key, value, generators)¶ Listas y sets por comprensión, expresiones de generadores, y diccionarios por comprensión.
elt(okeyyvalue) es un único nodo que representa la parte que va a ser evaluada por cada item.generatorses una lista de nodoscomprehension.>>> print(ast.dump(ast.parse('[x for x in numbers]', mode='eval'), indent=4)) Expression( body=ListComp( elt=Name(id='x', ctx=Load()), generators=[ comprehension( target=Name(id='x', ctx=Store()), iter=Name(id='numbers', ctx=Load()), ifs=[], is_async=0)])) >>> print(ast.dump(ast.parse('{x: x**2 for x in numbers}', mode='eval'), indent=4)) Expression( body=DictComp( key=Name(id='x', ctx=Load()), value=BinOp( left=Name(id='x', ctx=Load()), op=Pow(), right=Constant(value=2)), generators=[ comprehension( target=Name(id='x', ctx=Store()), iter=Name(id='numbers', ctx=Load()), ifs=[], is_async=0)])) >>> print(ast.dump(ast.parse('{x for x in numbers}', mode='eval'), indent=4)) Expression( body=SetComp( elt=Name(id='x', ctx=Load()), generators=[ comprehension( target=Name(id='x', ctx=Store()), iter=Name(id='numbers', ctx=Load()), ifs=[], is_async=0)]))
- 
class 
ast.comprehension(target, iter, ifs, is_async)¶ Una cláusula
foren una comprensión.targetes la referencia a usarse por cada elemento - típicamente un nodoNameoTuple.iteres el objeto por el cual se itera.ifses una lista de expresiones de prueba: cada cláusulaforpuede tener múltiplesifs.is_asyncindica que una compresión es asíncrona (usandoasync foren lugar defor). El valor es un entero (0 o 1).>>> print(ast.dump(ast.parse('[ord(c) for line in file for c in line]', mode='eval'), ... indent=4)) # Multiple comprehensions in one. Expression( body=ListComp( elt=Call( func=Name(id='ord', ctx=Load()), args=[ Name(id='c', ctx=Load())], keywords=[]), generators=[ comprehension( target=Name(id='line', ctx=Store()), iter=Name(id='file', ctx=Load()), ifs=[], is_async=0), comprehension( target=Name(id='c', ctx=Store()), iter=Name(id='line', ctx=Load()), ifs=[], is_async=0)])) >>> print(ast.dump(ast.parse('(n**2 for n in it if n>5 if n<10)', mode='eval'), ... indent=4)) # generator comprehension Expression( body=GeneratorExp( elt=BinOp( left=Name(id='n', ctx=Load()), op=Pow(), right=Constant(value=2)), generators=[ comprehension( target=Name(id='n', ctx=Store()), iter=Name(id='it', ctx=Load()), ifs=[ Compare( left=Name(id='n', ctx=Load()), ops=[ Gt()], comparators=[ Constant(value=5)]), Compare( left=Name(id='n', ctx=Load()), ops=[ Lt()], comparators=[ Constant(value=10)])], is_async=0)])) >>> print(ast.dump(ast.parse('[i async for i in soc]', mode='eval'), ... indent=4)) # Async comprehension Expression( body=ListComp( elt=Name(id='i', ctx=Load()), generators=[ comprehension( target=Name(id='i', ctx=Store()), iter=Name(id='soc', ctx=Load()), ifs=[], is_async=1)]))
Declaraciones¶
- 
class 
ast.Assign(targets, value, type_comment)¶ Una asignación.
targetses una lista de nodos, yvaluees un nodo único.Nodos múltiples en
targetsrepresenta asignar el mismo valor a cada uno. El desempaquetado se representa poniendo unaTupleoListentargets.- 
type_comment¶ type_commentes una cadena de caracteres opcional con la anotación de tipos como comentario.
>>> print(ast.dump(ast.parse('a = b = 1'), indent=4)) # Multiple assignment Module( body=[ Assign( targets=[ Name(id='a', ctx=Store()), Name(id='b', ctx=Store())], value=Constant(value=1))], type_ignores=[]) >>> print(ast.dump(ast.parse('a,b = c'), indent=4)) # Unpacking Module( body=[ Assign( targets=[ Tuple( elts=[ Name(id='a', ctx=Store()), Name(id='b', ctx=Store())], ctx=Store())], value=Name(id='c', ctx=Load()))], type_ignores=[])
- 
 
- 
class 
ast.AnnAssign(target, annotation, value, simple)¶ Una asignación con una anotación de tipos.
targetes un nodo único y puede ser unName, aAttributeo unSubscript.annotationes la anotación, como un nodoConstantoName.valuees un único nodo opcional.simplees un booleano que es True para un nodoNameen target que no aparece entre paréntesis y por ende son nombres puros y no expresiones.>>> print(ast.dump(ast.parse('c: int'), indent=4)) Module( body=[ AnnAssign( target=Name(id='c', ctx=Store()), annotation=Name(id='int', ctx=Load()), simple=1)], type_ignores=[]) >>> print(ast.dump(ast.parse('(a): int = 1'), indent=4)) # Annotation with parenthesis Module( body=[ AnnAssign( target=Name(id='a', ctx=Store()), annotation=Name(id='int', ctx=Load()), value=Constant(value=1), simple=0)], type_ignores=[]) >>> print(ast.dump(ast.parse('a.b: int'), indent=4)) # Attribute annotation Module( body=[ AnnAssign( target=Attribute( value=Name(id='a', ctx=Load()), attr='b', ctx=Store()), annotation=Name(id='int', ctx=Load()), simple=0)], type_ignores=[]) >>> print(ast.dump(ast.parse('a[1]: int'), indent=4)) # Subscript annotation Module( body=[ AnnAssign( target=Subscript( value=Name(id='a', ctx=Load()), slice=Constant(value=1), ctx=Store()), annotation=Name(id='int', ctx=Load()), simple=0)], type_ignores=[])
- 
class 
ast.AugAssign(target, op, value)¶ Asignación aumentada, como
a+=1. En el siguiente ejemplo,targetes un nodoNameparax(con el contextoStore),opesAddyvaluees unConstantcon valor 1.El atributo
targetno puede ser de claseTupleoList, a diferencia de los objetivos deAssign.>>> print(ast.dump(ast.parse('x += 2'), indent=4)) Module( body=[ AugAssign( target=Name(id='x', ctx=Store()), op=Add(), value=Constant(value=2))], type_ignores=[])
- 
class 
ast.Raise(exc, cause)¶ Una declaración
raise.exces el objeto de excepción a ser lanzado, normalmente unCallorName, oNonepara unraisesolo.causees la parte opcional parayenraise x from y.>>> print(ast.dump(ast.parse('raise x from y'), indent=4)) Module( body=[ Raise( exc=Name(id='x', ctx=Load()), cause=Name(id='y', ctx=Load()))], type_ignores=[])
- 
class 
ast.Assert(test, msg)¶ Una aserción.
testcontiene la condición, como un nodoCompare.msgcontiene el mensaje de fallo.>>> print(ast.dump(ast.parse('assert x,y'), indent=4)) Module( body=[ Assert( test=Name(id='x', ctx=Load()), msg=Name(id='y', ctx=Load()))], type_ignores=[])
- 
class 
ast.Delete(targets)¶ Contiene una declaración
del.targetses una lista de nodos, como nodosName,AttributeoSubscript.>>> print(ast.dump(ast.parse('del x,y,z'), indent=4)) Module( body=[ Delete( targets=[ Name(id='x', ctx=Del()), Name(id='y', ctx=Del()), Name(id='z', ctx=Del())])], type_ignores=[])
- 
class 
ast.Pass¶ Una declaración
pass.>>> print(ast.dump(ast.parse('pass'), indent=4)) Module( body=[ Pass()], type_ignores=[])
Otras declaraciones que solo son aplicables dentro de funciones o bucles descritos en otras secciones.
Importaciones¶
- 
class 
ast.Import(names)¶ Una declaración de importación.
nameses una lista de nodosalias.>>> print(ast.dump(ast.parse('import x,y,z'), indent=4)) Module( body=[ Import( names=[ alias(name='x'), alias(name='y'), alias(name='z')])], type_ignores=[])
- 
class 
ast.ImportFrom(module, names, level)¶ Representa
form x import y.modulees una cadena de caracteres sin formato del nombre “from”, sin puntos, oNonepara declaraciones comofrom . import foo.leveles un entero que contiene el nivel relativo de la importación (0 significa una importación absoluta).>>> print(ast.dump(ast.parse('from y import x,y,z'), indent=4)) Module( body=[ ImportFrom( module='y', names=[ alias(name='x'), alias(name='y'), alias(name='z')], level=0)], type_ignores=[])
- 
class 
ast.alias(name, asname)¶ Ambos parámetros son cadenas de caracteres sin formato para los nombres.
asnamepuede serNonesi se va a usar el nombre regular.>>> print(ast.dump(ast.parse('from ..foo.bar import a as b, c'), indent=4)) Module( body=[ ImportFrom( module='foo.bar', names=[ alias(name='a', asname='b'), alias(name='c')], level=2)], type_ignores=[])
Control de flujo¶
Nota
Cláusulas opcionales como``else`` se guardan como una lista vacía si no están presentes.
- 
class 
ast.If(test, body, orelse)¶ Una declaración
if.testcontiene un único nodo, como un nodoCompare.bodyyorelsecontiene cada uno una lista de nodos.Cláusulas
elifno tienen una representación especial en AST, pero pueden aparecer como nodos extraIfdentro de la secciónorelsedel nodo anterior.>>> print(ast.dump(ast.parse(""" ... if x: ... ... ... elif y: ... ... ... else: ... ... ... """), indent=4)) Module( body=[ If( test=Name(id='x', ctx=Load()), body=[ Expr( value=Constant(value=Ellipsis))], orelse=[ If( test=Name(id='y', ctx=Load()), body=[ Expr( value=Constant(value=Ellipsis))], orelse=[ Expr( value=Constant(value=Ellipsis))])])], type_ignores=[])
- 
class 
ast.For(target, iter, body, orelse, type_comment)¶ Un bucle
for.targetcontiene la(s) variable(s) donde asigna el bucle como un único nodoName,TupleoList.itercontiene el item por el cual se va recorrer como un único nodo.bodyyorelsecontienen una lista de nodos a ejecutar. Aquellos enorelseson ejecutados si el bucle termina normalmente, en contra de si terminan utilizando la declaraciónbreak.- 
type_comment¶ type_commentes una cadena de caracteres opcional con la anotación de tipos como comentario.
>>> print(ast.dump(ast.parse(""" ... for x in y: ... ... ... else: ... ... ... """), indent=4)) Module( body=[ For( target=Name(id='x', ctx=Store()), iter=Name(id='y', ctx=Load()), body=[ Expr( value=Constant(value=Ellipsis))], orelse=[ Expr( value=Constant(value=Ellipsis))])], type_ignores=[])
- 
 
- 
class 
ast.While(test, body, orelse)¶ Un bucle
while.testcontiene la condición, como un nodoCompare.>> print(ast.dump(ast.parse(""" ... while x: ... ... ... else: ... ... ... """), indent=4)) Module( body=[ While( test=Name(id='x', ctx=Load()), body=[ Expr( value=Constant(value=Ellipsis))], orelse=[ Expr( value=Constant(value=Ellipsis))])], type_ignores=[])
- 
class 
ast.Break¶ - 
class 
ast.Continue¶ Las declaraciones
breakycontinue.>>> print(ast.dump(ast.parse("""\ ... for a in b: ... if a > 5: ... break ... else: ... continue ... ... """), indent=4)) Module( body=[ For( target=Name(id='a', ctx=Store()), iter=Name(id='b', ctx=Load()), body=[ If( test=Compare( left=Name(id='a', ctx=Load()), ops=[ Gt()], comparators=[ Constant(value=5)]), body=[ Break()], orelse=[ Continue()])], orelse=[])], type_ignores=[])
- 
class 
ast.Try(body, handlers, orelse, finalbody)¶ Bloques
try. Todos los atributos son listas de nodos a ejecutar, excepto parahandlers, el cual es una lista de nodosExceptHandler.>>> print(ast.dump(ast.parse(""" ... try: ... ... ... except Exception: ... ... ... except OtherException as e: ... ... ... else: ... ... ... finally: ... ... ... """), indent=4)) Module( body=[ Try( body=[ Expr( value=Constant(value=Ellipsis))], handlers=[ ExceptHandler( type=Name(id='Exception', ctx=Load()), body=[ Expr( value=Constant(value=Ellipsis))]), ExceptHandler( type=Name(id='OtherException', ctx=Load()), name='e', body=[ Expr( value=Constant(value=Ellipsis))])], orelse=[ Expr( value=Constant(value=Ellipsis))], finalbody=[ Expr( value=Constant(value=Ellipsis))])], type_ignores=[])
- 
class 
ast.ExceptHandler(type, name, body)¶ Una sola cláusula
except.typees el tipo de excepción con el que coincidirá, normalmente un nodoName(oNonepara una cláusulaexcept:generalizada).namees una cadena sin formato para que el nombre contenga la excepción, oNonesi la cláusula no tieneas foo.bodyes una lista de nodos.>>> print(ast.dump(ast.parse("""\ ... try: ... a + 1 ... except TypeError: ... pass ... """), indent=4)) Module( body=[ Try( body=[ Expr( value=BinOp( left=Name(id='a', ctx=Load()), op=Add(), right=Constant(value=1)))], handlers=[ ExceptHandler( type=Name(id='TypeError', ctx=Load()), body=[ Pass()])], orelse=[], finalbody=[])], type_ignores=[])
- 
class 
ast.With(items, body, type_comment)¶ Un bloque
with.itemses una lista de nodoswithitemque representan los administradores de contexto, ybodyes el bloque con sangría dentro del contexto.- 
type_comment¶ type_commentes una cadena de caracteres opcional con la anotación de tipos como comentario.
- 
 
- 
class 
ast.withitem(context_expr, optional_vars)¶ Un administrador de contexto único en un bloque
with.context_expres el administrador de contexto, a menudo un nodoCall.optional_varses unName,TupleoListpara la parteas foo, oNonesi no se usa.>>> print(ast.dump(ast.parse("""\ ... with a as b, c as d: ... something(b, d) ... """), indent=4)) Module( body=[ With( items=[ withitem( context_expr=Name(id='a', ctx=Load()), optional_vars=Name(id='b', ctx=Store())), withitem( context_expr=Name(id='c', ctx=Load()), optional_vars=Name(id='d', ctx=Store()))], body=[ Expr( value=Call( func=Name(id='something', ctx=Load()), args=[ Name(id='b', ctx=Load()), Name(id='d', ctx=Load())], keywords=[]))])], type_ignores=[])
La coincidencia de patrones¶
- 
class 
ast.Match(subject, cases)¶ Una declaración
match.subjectcontiene el sujeto de la coincidencia (el objeto que se compara con los casos) ycasescontiene un iterable de nodosmatch_casecon los diferentes casos.
- 
class 
ast.match_case(pattern, guard, body)¶ Un patrón de caso único en una declaración
match.patterncontiene el patrón de coincidencia con el que se comparará el sujeto. Tenga en cuenta que los nodosASTproducidos para patrones difieren de los producidos para expresiones, incluso cuando comparten la misma sintaxis.El atributo
guardcontiene una expresión que se evaluará si el patrón coincide con el sujeto.bodycontiene una lista de nodos para ejecutar si el patrón coincide y el resultado de evaluar la expresión de protección es verdadero.>>> print(ast.dump(ast.parse(""" ... match x: ... case [x] if x>0: ... ... ... case tuple(): ... ... ... """), indent=4)) Module( body=[ Match( subject=Name(id='x', ctx=Load()), cases=[ match_case( pattern=MatchSequence( patterns=[ MatchAs(name='x')]), guard=Compare( left=Name(id='x', ctx=Load()), ops=[ Gt()], comparators=[ Constant(value=0)]), body=[ Expr( value=Constant(value=Ellipsis))]), match_case( pattern=MatchClass( cls=Name(id='tuple', ctx=Load()), patterns=[], kwd_attrs=[], kwd_patterns=[]), body=[ Expr( value=Constant(value=Ellipsis))])])], type_ignores=[])
- 
class 
ast.MatchValue(value)¶ Un patrón de valor o literal de coincidencia que se compara por igualdad.
valuees un nodo de expresión. Los nodos de valores permitidos están restringidos como se describe en la documentación de la declaración de coincidencia. Este patrón tiene éxito si el sujeto de la coincidencia es igual al valor evaluado.>>> print(ast.dump(ast.parse(""" ... match x: ... case "Relevant": ... ... ... """), indent=4)) Module( body=[ Match( subject=Name(id='x', ctx=Load()), cases=[ match_case( pattern=MatchValue( value=Constant(value='Relevant')), body=[ Expr( value=Constant(value=Ellipsis))])])], type_ignores=[])
- 
class 
ast.MatchSingleton(value)¶ Un patrón literal de coincidencia que se compara por identidad.
valuees el singleton que se va a comparar con:None,TrueoFalse. Este patrón tiene éxito si el sujeto de la coincidencia es la constante dada.>>> print(ast.dump(ast.parse(""" ... match x: ... case None: ... ... ... """), indent=4)) Module( body=[ Match( subject=Name(id='x', ctx=Load()), cases=[ match_case( pattern=MatchSingleton(value=None), body=[ Expr( value=Constant(value=Ellipsis))])])], type_ignores=[])
- 
class 
ast.MatchSequence(patterns)¶ Un patrón de secuencia de coincidencia.
patternscontiene los patrones que se compararán con los elementos del sujeto si el sujeto es una secuencia. Coincide con una secuencia de longitud variable si uno de los subpatrones es un nodoMatchStar; de lo contrario, coincide con una secuencia de longitud fija.>>> print(ast.dump(ast.parse(""" ... match x: ... case [1, 2]: ... ... ... """), indent=4)) Module( body=[ Match( subject=Name(id='x', ctx=Load()), cases=[ match_case( pattern=MatchSequence( patterns=[ MatchValue( value=Constant(value=1)), MatchValue( value=Constant(value=2))]), body=[ Expr( value=Constant(value=Ellipsis))])])], type_ignores=[])
- 
class 
ast.MatchStar(name)¶ Coincide con el resto de la secuencia en un patrón de secuencia de coincidencia de longitud variable. Si
nameno esNone, una lista que contiene los elementos de secuencia restantes está vinculada a ese nombre si el patrón de secuencia general es exitoso.>>> print(ast.dump(ast.parse(""" ... match x: ... case [1, 2, *rest]: ... ... ... case [*_]: ... ... ... """), indent=4)) Module( body=[ Match( subject=Name(id='x', ctx=Load()), cases=[ match_case( pattern=MatchSequence( patterns=[ MatchValue( value=Constant(value=1)), MatchValue( value=Constant(value=2)), MatchStar(name='rest')]), body=[ Expr( value=Constant(value=Ellipsis))]), match_case( pattern=MatchSequence( patterns=[ MatchStar()]), body=[ Expr( value=Constant(value=Ellipsis))])])], type_ignores=[])
- 
class 
ast.MatchMapping(keys, patterns, rest)¶ Un patrón de mapeo de coincidencias.
keyses una secuencia de nodos de expresión.patternses una secuencia correspondiente de nodos de patrón.restes un nombre opcional que se puede especificar para capturar los elementos de mapeo restantes. Las expresiones clave permitidas están restringidas como se describe en la documentación de la declaración de coincidencia.Este patrón tiene éxito si el sujeto es un mapeo, todas las expresiones clave evaluadas están presentes en el mapeo y el valor correspondiente a cada clave coincide con el subpatrón correspondiente. Si
restno esNone, un dict que contiene los elementos de mapeo restantes se vincula a ese nombre si el patrón de mapeo general es exitoso.>>> print(ast.dump(ast.parse(""" ... match x: ... case {1: _, 2: _}: ... ... ... case {**rest}: ... ... ... """), indent=4)) Module( body=[ Match( subject=Name(id='x', ctx=Load()), cases=[ match_case( pattern=MatchMapping( keys=[ Constant(value=1), Constant(value=2)], patterns=[ MatchAs(), MatchAs()]), body=[ Expr( value=Constant(value=Ellipsis))]), match_case( pattern=MatchMapping(keys=[], patterns=[], rest='rest'), body=[ Expr( value=Constant(value=Ellipsis))])])], type_ignores=[])
- 
class 
ast.MatchClass(cls, patterns, kwd_attrs, kwd_patterns)¶ Un patrón de clase coincidente.
clses una expresión que da la clase nominal que se va a emparejar.patternses una secuencia de nodos de patrón que se compararán con la secuencia definida por la clase de atributos de coincidencia de patrones.kwd_attrses una secuencia de atributos adicionales que deben coincidir (especificados como argumentos de palabra clave en el patrón de clase),kwd_patternsson los patrones correspondientes (especificados como valores de palabras clave en el patrón de clase).Este patrón tiene éxito si el sujeto es una instancia de la clase nominada, todos los patrones posicionales coinciden con los atributos definidos por la clase correspondientes y cualquier atributo de palabra clave especificado coincide con su patrón correspondiente.
Nota: las clases pueden definir una propiedad que retorna self para hacer coincidir un nodo de patrón con la instancia que se está comparando. Varios tipos incorporados también se combinan de esa manera, como se describe en la documentación de la declaración de coincidencia.
>>> print(ast.dump(ast.parse(""" ... match x: ... case Point2D(0, 0): ... ... ... case Point3D(x=0, y=0, z=0): ... ... ... """), indent=4)) Module( body=[ Match( subject=Name(id='x', ctx=Load()), cases=[ match_case( pattern=MatchClass( cls=Name(id='Point2D', ctx=Load()), patterns=[ MatchValue( value=Constant(value=0)), MatchValue( value=Constant(value=0))], kwd_attrs=[], kwd_patterns=[]), body=[ Expr( value=Constant(value=Ellipsis))]), match_case( pattern=MatchClass( cls=Name(id='Point3D', ctx=Load()), patterns=[], kwd_attrs=[ 'x', 'y', 'z'], kwd_patterns=[ MatchValue( value=Constant(value=0)), MatchValue( value=Constant(value=0)), MatchValue( value=Constant(value=0))]), body=[ Expr( value=Constant(value=Ellipsis))])])], type_ignores=[])
- 
class 
ast.MatchAs(pattern, name)¶ Una coincidencia «como patrón», patrón de captura o patrón comodín.
patterncontiene el patrón de coincidencia con el que se comparará el sujeto. Si el patrón esNone, el nodo representa un patrón de captura (es decir, un nombre simple) y siempre tendrá éxito.El atributo
namecontiene el nombre que se vinculará si el patrón tiene éxito. SinameesNone,patterntambién debe serNoney el nodo representa el patrón comodín.>>> print(ast.dump(ast.parse(""" ... match x: ... case [x] as y: ... ... ... case _: ... ... ... """), indent=4)) Module( body=[ Match( subject=Name(id='x', ctx=Load()), cases=[ match_case( pattern=MatchAs( pattern=MatchSequence( patterns=[ MatchAs(name='x')]), name='y'), body=[ Expr( value=Constant(value=Ellipsis))]), match_case( pattern=MatchAs(), body=[ Expr( value=Constant(value=Ellipsis))])])], type_ignores=[])
- 
class 
ast.MatchOr(patterns)¶ Una coincidencia «o patrón». Un patrón-o hace coincidir cada uno de sus subpatrones con el sujeto, hasta que uno tiene éxito. Entonces se considera que el patrón-o tiene éxito. Si ninguno de los subpatrones tiene éxito, el patrón o falla. El atributo
patternscontiene una lista de nodos de patrones de coincidencia que se compararán con el sujeto.>>> print(ast.dump(ast.parse(""" ... match x: ... case [x] | (y): ... ... ... """), indent=4)) Module( body=[ Match( subject=Name(id='x', ctx=Load()), cases=[ match_case( pattern=MatchOr( patterns=[ MatchSequence( patterns=[ MatchAs(name='x')]), MatchAs(name='y')]), body=[ Expr( value=Constant(value=Ellipsis))])])], type_ignores=[])
Definiciones de función y clase¶
- 
class 
ast.FunctionDef(name, args, body, decorator_list, returns, type_comment)¶ Una definición de función.
namees una cadena de caracteres sin formato del nombre de la función.argses un nodoarguments.bodyes la lista de nodos dentro de la función.decorator_listes la lista de decoradores que se aplicarán, almacenados en el exterior primero (es decir, el primero de la lista se aplicará al final).returnses la anotación de retorno.
- 
type_comment¶ type_commentes una cadena de caracteres opcional con la anotación de tipos como comentario.
- 
class 
ast.Lambda(args, body)¶ lambdaes una definición de función mínima que se puede utilizar dentro de una expresión. A diferencia deFunctionDef,bodytiene un solo nodo.>>> print(ast.dump(ast.parse('lambda x,y: ...'), indent=4)) Module( body=[ Expr( value=Lambda( args=arguments( posonlyargs=[], args=[ arg(arg='x'), arg(arg='y')], kwonlyargs=[], kw_defaults=[], defaults=[]), body=Constant(value=Ellipsis)))], type_ignores=[])
- 
class 
ast.arguments(posonlyargs, args, vararg, kwonlyargs, kw_defaults, kwarg, defaults)¶ Los argumentos para una función.
posonlyargs,argsykwonlyargsson listas de nodosarg.varargykwargson nodosargúnicos, en referencia a los parámetros*args, **kwargs.kw_defaultses una lista de valores predeterminados para argumentos de solo palabras clave. Si uno esNone, se requiere el argumento correspondiente.defaultses una lista de valores predeterminados para argumentos que se pueden pasar posicionalmente. Si hay menos valores predeterminados, corresponden a los últimos n argumentos.
- 
class 
ast.arg(arg, annotation, type_comment)¶ Un solo argumento en una lista.
arges una cadena sin formato del nombre del argumento,annotationes su anotación, como un nodoStroName.- 
type_comment¶ type_commentes una cadena opcional con la anotación de tipo como comentario
>>> print(ast.dump(ast.parse("""\ ... @decorator1 ... @decorator2 ... def f(a: 'annotation', b=1, c=2, *d, e, f=3, **g) -> 'return annotation': ... pass ... """), indent=4)) Module( body=[ FunctionDef( name='f', args=arguments( posonlyargs=[], args=[ arg( arg='a', annotation=Constant(value='annotation')), arg(arg='b'), arg(arg='c')], vararg=arg(arg='d'), kwonlyargs=[ arg(arg='e'), arg(arg='f')], kw_defaults=[ None, Constant(value=3)], kwarg=arg(arg='g'), defaults=[ Constant(value=1), Constant(value=2)]), body=[ Pass()], decorator_list=[ Name(id='decorator1', ctx=Load()), Name(id='decorator2', ctx=Load())], returns=Constant(value='return annotation'))], type_ignores=[])
- 
 
- 
class 
ast.Return(value)¶ Una declaración
return.>>> print(ast.dump(ast.parse('return 4'), indent=4)) Module( body=[ Return( value=Constant(value=4))], type_ignores=[])
- 
class 
ast.Yield(value)¶ - 
class 
ast.YieldFrom(value)¶ Una expresión
yieldoyield from. Debido a que se trata de expresiones, deben incluirse en un nodoExprsi no se utiliza el valor retornado.>>> print(ast.dump(ast.parse('yield x'), indent=4)) Module( body=[ Expr( value=Yield( value=Name(id='x', ctx=Load())))], type_ignores=[]) >>> print(ast.dump(ast.parse('yield from x'), indent=4)) Module( body=[ Expr( value=YieldFrom( value=Name(id='x', ctx=Load())))], type_ignores=[])
- 
class 
ast.Global(names)¶ - 
class 
ast.Nonlocal(names)¶ Declaraciones
globalynonlocal.nameses una lista de cadenas sin formato.>>> print(ast.dump(ast.parse('global x,y,z'), indent=4)) Module( body=[ Global( names=[ 'x', 'y', 'z'])], type_ignores=[]) >>> print(ast.dump(ast.parse('nonlocal x,y,z'), indent=4)) Module( body=[ Nonlocal( names=[ 'x', 'y', 'z'])], type_ignores=[])
- 
class 
ast.ClassDef(name, bases, keywords, starargs, kwargs, body, decorator_list)¶ Una definición de clase.
namees una cadena sin formato para el nombre de la clasebaseses una lista de nodos para clases base especificadas explícitamente.keywordses una lista de nodoskeyword, principalmente para “metaclase”. Otras palabras clave se pasarán a la metaclase, según PEP-3115.starargsykwargsson cada uno un solo nodo, como en una llamada de función. Los starargs se expandirán para unirse a la lista de clases base y los kwargs se pasarán a la metaclase.bodyes una lista de nodos que representan el código dentro de la definición de clase.decorator_listes una lista de nodos, como enFunctionDef.
>>> print(ast.dump(ast.parse("""\ ... @decorator1 ... @decorator2 ... class Foo(base1, base2, metaclass=meta): ... pass ... """), indent=4)) Module( body=[ ClassDef( name='Foo', bases=[ Name(id='base1', ctx=Load()), Name(id='base2', ctx=Load())], keywords=[ keyword( arg='metaclass', value=Name(id='meta', ctx=Load()))], body=[ Pass()], decorator_list=[ Name(id='decorator1', ctx=Load()), Name(id='decorator2', ctx=Load())])], type_ignores=[])
Async y await¶
- 
class 
ast.AsyncFunctionDef(name, args, body, decorator_list, returns, type_comment)¶ Una definición de función
async def. Tiene los mismos campos queFunctionDef.
- 
class 
ast.Await(value)¶ Una expresión
await.valuees lo que espera. Solo válido en el cuerpo de unAsyncFunctionDef.
>>> print(ast.dump(ast.parse("""\
... async def f():
...     await other_func()
... """), indent=4))
Module(
    body=[
        AsyncFunctionDef(
            name='f',
            args=arguments(
                posonlyargs=[],
                args=[],
                kwonlyargs=[],
                kw_defaults=[],
                defaults=[]),
            body=[
                Expr(
                    value=Await(
                        value=Call(
                            func=Name(id='other_func', ctx=Load()),
                            args=[],
                            keywords=[])))],
            decorator_list=[])],
    type_ignores=[])
- 
class 
ast.AsyncFor(target, iter, body, orelse, type_comment)¶ - 
class 
ast.AsyncWith(items, body, type_comment)¶ Bucles
async fory administradores de contextoasync with. Tienen los mismos campos queForyWith, respectivamente. Solo válido en el cuerpo de unAsyncFunctionDef.
Nota
Cuando ast.parse() analiza una cadena, los nodos de operador (subclases de ast.operator, ast.unaryop, ast.cmpop, ast.boolop y ast.expr_context) en el árbol retornado serán singletons. Los cambios en uno se reflejarán en todas las demás ocurrencias del mismo valor (por ejemplo, ast.Add).
Ayudantes de ast¶
Además de las clases de nodo, el módulo ast define estas funciones y clases de utilidad para atravesar árboles de sintaxis abstracta:
- 
ast.parse(source, filename='<unknown>', mode='exec', *, type_comments=False, feature_version=None)¶ Analiza la fuente en un nodo AST. Equivalente a
compile(source, filename, mode, ast.PyCF_ONLY_AST).Si se proporciona
type_comments=True, el analizador se modifica para verificar y retornar los comentarios de tipo según lo especificado por PEP 484 y PEP 526. Esto es equivalente a agregarast.PyCF_TYPE_COMMENTSa los flags pasados acompile(). Esto informará errores de sintaxis para comentarios de tipo fuera de lugar. Sin este flag, los comentarios de tipo se ignorarán y el campotype_commenten los nodos AST seleccionados siempre seráNone. Además, las ubicaciones de los comentarios# type: ignorese retornarán como el atributotype_ignoresdeModule(de lo contrario, siempre es una lista vacía).Además, si
modoes'func_type', la sintaxis de entrada se modifica para corresponder a PEP 484 «comentarios de tipo de firma», por ejemplo(str, int) -> List[str].Además, establece
feature_versionen una tupla(major, minor)intentará analizar usando la gramática de esa versión de Python. Actualmentemajordebe ser igual a3. Por ejemplo, establecefeature_version=(3, 4)permitirá el uso deasyncyawaitcomo nombres de variables. La versión más baja admitida es(3, 4); la más alto essys.version_info[0:2].Si la fuente contiene un carácter nulo (”0”), se lanza
ValueError.Advertencia
Tenga en cuenta que analizar correctamente el código fuente en un objeto AST no garantiza que el código fuente proporcionado sea un código Python válido que se pueda ejecutar, ya que el paso de compilación puede lanzar más excepciones
SyntaxError. Por ejemplo, la fuentereturn 42genera un nodo AST válido para una declaración de retorno, pero no se puede compilar solo (debe estar dentro de un nodo de función).En particular,
ast.parse()no realizará ninguna verificación de alcance, lo que hace el paso de compilación.Advertencia
Es posible bloquear el intérprete de Python con una cadena de caracteres suficientemente grande/compleja debido a las limitaciones de profundidad de pila en el compilador AST de Python.
Distinto en la versión 3.8: Se agregaron
type_comments,mode='func_type'yfeature_version.
- 
ast.unparse(ast_obj)¶ Analice un objeto
ast.ASTy genere una cadena con código que produciría un objetoast.ASTequivalente si se analiza conast.parse().Advertencia
La cadena de código producida no será necesariamente igual al código original que generó el objeto
ast.AST(sin ninguna optimización del compilador, como tuplas constantes / frozensets).Advertencia
Intentar descomprimir una expresión muy compleja daría como resultado
RecursionError.Nuevo en la versión 3.9.
- 
ast.literal_eval(node_or_string)¶ Evaluate an expression node or a string containing only a Python literal or container display. The string or node provided may only consist of the following Python literal structures: strings, bytes, numbers, tuples, lists, dicts, sets, booleans,
NoneandEllipsis.This can be used for evaluating strings containing Python values without the need to parse the values oneself. It is not capable of evaluating arbitrarily complex expressions, for example involving operators or indexing.
This function had been documented as «safe» in the past without defining what that meant. That was misleading. This is specifically designed not to execute Python code, unlike the more general
eval(). There is no namespace, no name lookups, or ability to call out. But it is not free from attack: A relatively small input can lead to memory exhaustion or to C stack exhaustion, crashing the process. There is also the possibility for excessive CPU consumption denial of service on some inputs. Calling it on untrusted data is thus not recommended.Advertencia
It is possible to crash the Python interpreter due to stack depth limitations in Python’s AST compiler.
Puede generar
ValueError,TypeError,SyntaxError,MemoryErroryRecursionErrordependiendo de la entrada mal formada.Distinto en la versión 3.2: Ahora permite bytes y establece literales.
Distinto en la versión 3.9: Ahora admite la creación de conjuntos vacíos con
'set()'.Distinto en la versión 3.10: Para las entradas de cadena, los espacios iniciales y las tabulaciones ahora se eliminan.
- 
ast.get_docstring(node, clean=True)¶ Retorna la cadena de caracteres de documentación del node dado (que debe ser un nodo
FunctionDef,AsyncFunctionDef,ClassDef, oModule), oNonesi no tiene docstring. Si clean es verdadero, limpia la sangría del docstring coninspect.cleandoc().Distinto en la versión 3.5:
AsyncFunctionDefahora está soportada.
- 
ast.get_source_segment(source, node, *, padded=False)¶ Obtenga el segmento de código fuente del source que generó node. Si falta información de ubicación (
lineno,end_lineno,col_offset, oend_col_offset), retornaNone.Si padded es
True, la primera línea de una declaración de varias líneas se rellenará con espacios para que coincidan con su posición original.Nuevo en la versión 3.8.
- 
ast.fix_missing_locations(node)¶ Cuando compila un árbol de nodos con
compile(), el compilador espera los atributoslinenoycol_offsetpara cada nodo que los soporta. Es bastante tedioso completar los nodos generados, por lo que este ayudante agrega estos atributos de forma recursiva donde aún no están establecidos, configurándolos en los valores del nodo principal. Funciona de forma recursiva comenzando en node.
- 
ast.increment_lineno(node, n=1)¶ Incremente el número de línea y el número de línea final de cada nodo en el árbol comenzando en node por n. Esto es útil para «mover código» a una ubicación diferente en un archivo.
- 
ast.copy_location(new_node, old_node)¶ Copia la ubicación de origen (
lineno,col_offset,end_lineno, yend_col_offset) de old_node a new_node si es posible, y retorna new_node.
- 
ast.iter_fields(node)¶ Produce (yield) una tupla de
(fieldname, value)para cada campo ennode._fieldsque está presente en node.
- 
ast.iter_child_nodes(node)¶ Cede todos los nodos secundarios directos de node, es decir, todos los campos que son nodos y todos los elementos de campos que son listas de nodos.
- 
ast.walk(node)¶ Recursivamente produce todos los nodos descendientes en el árbol comenzando en node (incluido node en sí mismo), en ningún orden especificado. Esto es útil si solo desea modificar los nodos en su lugar y no le importa el contexto.
- 
class 
ast.NodeVisitor¶ Una clase base de visitante de nodo que recorre el árbol de sintaxis abstracta y llama a una función de visitante para cada nodo encontrado. Esta función puede retornar un valor que se reenvía mediante el método
visit().Esta clase está destinada a ser subclase, con la subclase agregando métodos de visitante.
- 
visit(node)¶ Visita un nodo. La implementación predeterminada llama al método llamado
self.visit_classnamedonde classname es el nombre de la clase de nodo, ogeneric_visit()si ese método no existe.
- 
generic_visit(node)¶ Este visitante llama
visit()en todos los hijos del nodo.Tenga en cuenta que los nodos secundarios de los nodos que tienen un método de visitante personalizado no se visitarán a menos que el visitante llame
generic_visit()o los visite a sí mismo.
No use
NodeVisitorsi desea aplicar cambios a los nodos durante el recorrido. Para esto existe un visitante especial (NodeTransformer) que permite modificaciones.Obsoleto desde la versión 3.8: Los métodos
visit_Num(),visit_Str(),visit_Bytes(),visit_NameConstant()yvisit_Ellipsis()están en desuso ahora y no serán llamados en futuras versiones de Python. Agregue el métodovisit_Constant()para manejar todos los nodos constantes.- 
 
- 
class 
ast.NodeTransformer¶ Una subclase de
NodeVisitorque recorre el árbol de sintaxis abstracta y permite la modificación de nodos.La clase
NodeTransformerrecorrerá el AST y usará el valor de retorno de los métodos del visitante para reemplazar o eliminar el nodo anterior. Si el valor de retorno del método de visitante esNone, el nodo se eliminará de su ubicación; de lo contrario, se reemplazará con el valor de retorno. El valor de retorno puede ser el nodo original, en cuyo caso no se realiza ningún reemplazo.Aquí hay un transformador de ejemplo que reescribe todas las apariciones de búsquedas de nombres (
foo) endata['foo']:class RewriteName(NodeTransformer): def visit_Name(self, node): return Subscript( value=Name(id='data', ctx=Load()), slice=Constant(value=node.id), ctx=node.ctx )
Tenga en cuenta que si el nodo en el que está operando tiene nodos secundarios, debe transformar los nodos secundarios usted mismo o llamar primero al método
generic_visit()para el nodo.Para los nodos que formaban parte de una colección de declaraciones (que se aplica a todos los nodos de declaración), el visitante también puede retornar una lista de nodos en lugar de solo un nodo.
Si
NodeTransformerintroduce nuevos nodos (que no eran parte del árbol original) sin darles información de ubicación (comolineno),fix_missing_locations()debería llamarse con el nuevo sub-árbol para recalcular la información de ubicacióntree = ast.parse('foo', mode='eval') new_tree = fix_missing_locations(RewriteName().visit(tree))
Usualmente usas el transformador así:
node = YourTransformer().visit(node)
- 
ast.dump(node, annotate_fields=True, include_attributes=False, *, indent=None)¶ Retorna un volcado formateado del árbol en node. Esto es principalmente útil para propósitos de depuración. Si annotate_fields es verdadero (por defecto), la cadena de caracteres retornada mostrará los nombres y los valores de los campos. Si annotate_fields es falso, la cadena de resultados será más compacta omitiendo nombres de campo no ambiguos. Los atributos como los números de línea y las compensaciones de columna no se vuelcan de forma predeterminada. Si esto se desea, include_attributes se puede establecer en verdadero.
Si indent es un entero no negativo o una cadena de caracteres, entonces el árbol será impreso de forma linda con ese nivel de sangría. Un nivel de sangría de 0, negativo, o
""solo insertará nuevas líneas.None(el valor por defecto) selecciona la representación de línea simple. Al usar un entero positivo se sangrará esa cantidad de espacios como sangría. Si indent es una cadena de caracteres (como"\t"), esa cadena se usa para sangrar cada nivel.Distinto en la versión 3.9: Añadida la opción indent.
Banderas del compilador¶
Los siguientes indicadores pueden pasarse a compile() para cambiar los efectos en la compilación de un programa:
- 
ast.PyCF_ALLOW_TOP_LEVEL_AWAIT¶ Habilita el soporte para
await,async for,async withy comprensiones asíncronas de nivel superior.Nuevo en la versión 3.8.
- 
ast.PyCF_ONLY_AST¶ Genera y retorna un árbol de sintaxis abstracto en lugar de retornar un objeto de código compilado.
Uso en línea de comandos¶
Nuevo en la versión 3.9.
El módulo ast puede ser ejecutado como un script desde la línea de comandos. Es tan simple como:
python -m ast [-m <mode>] [-a] [infile]
Las siguientes opciones son aceptadas:
- 
-h,--help¶ Muestra el mensaje de ayuda y sale.
- 
-m<mode>¶ - 
--mode<mode>¶ Especifica qué tipo de código debe ser compilado, como el argumento mode en
parse().
- 
--no-type-comments¶ No analizar los comentarios de tipo.
- 
-a,--include-attributes¶ Incluye atributos como números de línea y sangrías.
Si infile es especificado, su contenido es analizado a AST y mostrado en stdout. De otra forma, el contenido es leído desde stdin.
Ver también
Green Tree Snakes, un recurso de documentación externo, tiene buenos detalles sobre cómo trabajar con Python AST.
ASTTokens anota ASTs de Python con la posición de tokens y texto en el código fuente que los genera. Esto es de ayuda para herramientas que hacen transformaciones de código fuente.
leoAst.py unifies the token-based and parse-tree-based views of python programs by inserting two-way links between tokens and ast nodes.
LibCST analiza código como Árboles de Sintaxis Concreta que se ven como ASTs y mantienen todos los detalles de formato. Es útil para construir herramientas de refactor automáticas y linters.
Parso es un analizador de Python que soporta recuperación de errores y análisis sintáctico de ida y vuelta para las diferentes versiones de Python (en múltiples versiones de Python). Parso también es capaz de enlistar múltiples errores de sintaxis en tu archivo de Python.