如何从函数中的exec返回值?

use*_*172 2 python string exec python-2.7

我尝试:

def test(w,sli):
    s = "'{0}'{1}".format(w,sli)
    exec(s)
    return s

print test("TEST12344","[:2]")
Run Code Online (Sandbox Code Playgroud)

其返回值“ TEST12344” [:2]

如何从函数中的exec返回值

All*_*ric 7

考虑运行以下代码。

code = """
def func():
    print("std out")
    return "expr out"
func()
"""
Run Code Online (Sandbox Code Playgroud)

在Python控制台上

如果您func()在python控制台上运行,则输出将类似于:

>>> def func():
...     print("std out")
...     return "expr out"
...
>>> func()
std out
'expr out'
Run Code Online (Sandbox Code Playgroud)

与执行

>>> exec(code)
std out
>>> print(exec(code))
std out
None
Run Code Online (Sandbox Code Playgroud)

如您所见,返回值为None。

与评估

>>> eval(code)
Run Code Online (Sandbox Code Playgroud)

会产生错误。

所以我做了我的exec_with_return()

import ast
import copy
def convertExpr2Expression(Expr):
        Expr.lineno = 0
        Expr.col_offset = 0
        result = ast.Expression(Expr.value, lineno=0, col_offset = 0)

        return result
def exec_with_return(code):
    code_ast = ast.parse(code)

    init_ast = copy.deepcopy(code_ast)
    init_ast.body = code_ast.body[:-1]

    last_ast = copy.deepcopy(code_ast)
    last_ast.body = code_ast.body[-1:]

    exec(compile(init_ast, "<ast>", "exec"), globals())
    if type(last_ast.body[0]) == ast.Expr:
        return eval(compile(convertExpr2Expression(last_ast.body[0]), "<ast>", "eval"),globals())
    else:
        exec(compile(last_ast, "<ast>", "exec"),globals())

exec_with_return(code)
Run Code Online (Sandbox Code Playgroud)


Tig*_*kT3 5

exec()不只是计算表达式,它执行代码。您必须exec()调用中保存引用。

def test(w, sli):
    exec('s = "{}"{}'.format(w, sli))
    return s
Run Code Online (Sandbox Code Playgroud)

如果您只想计算表达式,请使用eval()并保存对返回值的引用:

def test(w,sli):
    s = "'{0}'{1}".format(w,sli)
    s = eval(s)
    return s
Run Code Online (Sandbox Code Playgroud)

但是,我建议尽可能避免在任何实际代码中使用exec()eval()。如果您使用它,请确保您有充分的理由这样做。

  • 这在python 3中不起作用,为`s`提供`NameError` (3认同)