本文整理匯總了Python中_ast.Expr方法的典型用法代碼示例。如果您正苦於以下問題:Python _ast.Expr方法的具體用法?Python _ast.Expr怎麽用?Python _ast.Expr使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類_ast
的用法示例。
在下文中一共展示了_ast.Expr方法的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: run
# 需要導入模塊: import _ast [as 別名]
# 或者: from _ast import Expr [as 別名]
def run(self, node, input_state):
result_state = input_state.copy()
block = node.data
constraints = self.cfg.block_constraints
for stmt in block.statements:
native = stmt.native
if isinstance(native, _ast.Assign) or isinstance(native, _ast.AugAssign):
self.transfer_assign(result_state, native, stmt.start_bytecode_index)
elif isinstance(native, _ast.Expr):
value = native.value
logger.debug("Stmt kind: %s", type(value))
if isinstance(value, _ast.Call):
self.transfer_call(result_state, native, stmt.start_bytecode_index)
else:
logger.error("Unknown stmt: %s", dump_native_ast(native))
return result_state
# Assign: a <- b
示例2: visit_expr
# 需要導入模塊: import _ast [as 別名]
# 或者: from _ast import Expr [as 別名]
def visit_expr(self, node, parent):
"""visit a Expr node by returning a fresh instance of it"""
newnode = nodes.Expr(node.lineno, node.col_offset, parent)
newnode.postinit(self.visit(node.value, newnode))
return newnode
示例3: _get_doc
# 需要導入模塊: import _ast [as 別名]
# 或者: from _ast import Expr [as 別名]
def _get_doc(node):
try:
if isinstance(node.body[0], _ast.Expr) and isinstance(node.body[0].value, _ast.Str):
doc = node.body[0].value.s
node.body = node.body[1:]
return node, doc
except IndexError:
pass # ast built from scratch
return node, None
示例4: to_python_statment
# 需要導入模塊: import _ast [as 別名]
# 或者: from _ast import Expr [as 別名]
def to_python_statment(bytecode):
i = len(bytecode) - 1
while i >= 0:
index, lineno, op, arg, cflow_in, code_object = bytecode[i]
prev_op = bytecode[i - 1][2] if i > 1 else -1
if op in (PRINT_ITEM, PRINT_NEWLINE, PRINT_ITEM_TO, PRINT_NEWLINE_TO):
_, stmt = Statement.to_print_statement(i, op, bytecode)
return stmt
elif op in CALL_OPCODES:
_, call = Statement.make_call(i, bytecode)
return _ast.Expr(call)
elif op == COMPARE_OP:
_, cmp_expr = Statement.make_comparator(i, bytecode)
return _ast.Expr(cmp_expr)
elif op in STORE_OPCODES and prev_op not in (MAKE_FUNCTION, BUILD_CLASS):
_, store_stmt = Statement.make_assign(i, bytecode)
return store_stmt
elif op in STORE_SLICE_OPCODES or op in DELETE_SLICE_OPCODES:
_, store_stmt = Statement.make_store_delete_slice(i, bytecode)
return store_stmt
elif op in DELETE_OPCODES:
_, store_stmt = Statement.make_delete(i, bytecode)
return store_stmt
else:
logger.debug("Unhandled >> STMT:\n%s", show_bytecode(bytecode))
i -= 1
return None
示例5: visit_expr
# 需要導入模塊: import _ast [as 別名]
# 或者: from _ast import Expr [as 別名]
def visit_expr(self, node: _ast.Expr): # value,
return self._run(node.value)
示例6: isDocstring
# 需要導入模塊: import _ast [as 別名]
# 或者: from _ast import Expr [as 別名]
def isDocstring(self, node):
"""
Determine if the given node is a docstring, as long as it is at the
correct place in the node tree.
"""
return isinstance(node, ast.Str) or (isinstance(node, ast.Expr) and
isinstance(node.value, ast.Str))
示例7: getDocstring
# 需要導入模塊: import _ast [as 別名]
# 或者: from _ast import Expr [as 別名]
def getDocstring(self, node):
if isinstance(node, ast.Expr):
node = node.value
if not isinstance(node, ast.Str):
return (None, None)
if PYPY:
doctest_lineno = node.lineno - 1
else:
# Computed incorrectly if the docstring has backslash
doctest_lineno = node.lineno - node.s.count('\n') - 1
return (node.s, doctest_lineno)
示例8: parse_function
# 需要導入模塊: import _ast [as 別名]
# 或者: from _ast import Expr [as 別名]
def parse_function(node):
old_style = None
new_style = None
output = None
setup = []
setup_done = False
title, details = parse_docstring(ast.get_docstring(node, clean=True))
name = node.name[5:] if node.name.startswith('test_') else node.name
for n in node.body:
# Ignore the docstring
if isinstance(n, _ast.Expr) and isinstance(n.value, _ast.Str):
continue
if isinstance(n, _ast.Assign) and n.targets[0].id == 'old_result':
setup_done = True
old_style = unparse(n.value, strip=True)
if isinstance(n, _ast.Assign) and n.targets[0].id == 'new_result':
setup_done = True
new_style = unparse(n.value, strip=True)
if isinstance(n, _ast.Assert) and isinstance(
n.test.comparators[0], _ast.Str):
setup_done = True
output = n.test.comparators[0].s
if not setup_done:
setup.append(n)
if setup:
setup = unparse(setup, strip=True)
return Example(
name,
title,
details,
setup or "",
old_style or "",
new_style or "",
output or ""
)
示例9: getDocstring
# 需要導入模塊: import _ast [as 別名]
# 或者: from _ast import Expr [as 別名]
def getDocstring(self, node):
if isinstance(node, ast.Expr):
node = node.value
if not isinstance(node, ast.Str):
return (None, None)
# Computed incorrectly if the docstring has backslash
doctest_lineno = node.lineno - node.s.count('\n') - 1
return (node.s, doctest_lineno)