3

ast.NodeVisitor.generic_visit()を操作するだけで、Pythonでast.NodeVisitorのインスタンスに対してポストオーダートラバーサルを実行することは可能ですか?これは私がしました:

class ExpParser(ast.NodeVisitor):

    def generic_visit(self, node):
        for x in ast.iter_child_nodes(node):
            ast.NodeVisitor.generic_visit(self, x)
        ast.NodeVisitor.generic_visit(self, node)

    def visit_BinOp(self, node):
        print type(node.op).__name__ 

    def visit_Name(self, node):
        print node.id

if __name__ == '__main__':
    node = ast.parse("T1+T2*T3")
    v = ExpParser()
    v.visit(node)

これは私に与えました:

T1
T2
T3
Mult
Add

私はそれが私に与えて欲しい:

T2
T3
Mult
T1
Add

どうすればいいですか?行き詰まってください。

4

1 に答える 1

3

このようなことを試してください

import ast

class ExpParser(ast.NodeVisitor):

    def generic_visit(self, node):
        for field, value in reversed(list(ast.iter_fields(node))):
            if isinstance(value, list):
                for item in value:
                    if isinstance(item, ast.AST):
                        self.visit(item)
            elif isinstance(value, ast.AST):
                self.visit(value)

    def visit_BinOp(self, node):
        self.generic_visit(node)
        print type(node.op).__name__ 

    def visit_Name(self, node):
        self.generic_visit(node)
        print node.id

if __name__ == '__main__':
    node = ast.parse("T1+T2*T3")
    v = ExpParser()
    v.visit(node)

各 visit メソッドで generic_visit を呼び出すことを忘れないでください。または、自動的に処理するように visit メソッドを再実装してください。

于 2012-04-09T23:15:07.620 に答える