【python】exec内置函数释义
- 官方释义
 - 样例
 - 注意事项
 - 拓展
 - 感谢及参考博文
 
官方释义
官方Python API文档镇楼
exec(object, globals=None, locals=None, /, *, closure=None)
支持动态执行 Python 代码, object 必须是字符串或者代码对象。
 需要特别注意以下两点,后面详讲,
 
顺便一提,exec和eval都属于python内置函数,功能是将里面的字符串当做命令执行;
 区别在于eval有返回值,但不能执行赋值命令;
 exec可以执行赋值命令。
样例
    exec("print('Hello World!')")
 
注意事项
这里主要是想讲一下注意事项,如何在某个函数内执行exec。
 像下面代码,直接运行达不到预期效果
def run():
    exec("b  = a")
    print(b)
if __name__ == '__main__':
    a = 5
    b = 6
    run()
 
输出为6
这里就是要注意官方文档最后讲的区分全局变量和局部变量,可以将他们打印出来,
def run():
    print(locals())
    print(globals())
    print("=============================================")
    exec("b  = a")
    print(globals())
    print(locals())
    print("=============================================")
    print(locals()["b"])
    print(b)
if __name__ == '__main__':
    a = 5
    b = 6
    run()
 
输出结果为:
{}
{'__name__': '__main__', '__doc__': None, '__package__': None, '__loader__': <_frozen_importlib_external.SourceFileLoader object at 0x00000000011BB518>, '__spec__': None, '__annotations__': {}, '__builtins__': <module 'builtins' (built-in)>, '__file__': 'E:/Develop/python/test/a.py', '__cached__': None, 'Net': <class '__main__.Net'>, 'run': <function run at 0x00000000010B2E18>, 'a': 5, 'b': 6}
=============================================
{'__name__': '__main__', '__doc__': None, '__package__': None, '__loader__': <_frozen_importlib_external.SourceFileLoader object at 0x00000000011BB518>, '__spec__': None, '__annotations__': {}, '__builtins__': <module 'builtins' (built-in)>, '__file__': 'E:/Develop/python/test/a.py', '__cached__': None, 'Net': <class '__main__.Net'>, 'run': <function run at 0x00000000010B2E18>, 'a': 5, 'b': 6}
{'b': 5}
=============================================
5
6
 
可以看到他修改的是局部变量,全局变量是没有变得,如果想达到同样效果,可以将之前代码改为下面
def run():
    exec("b  = a", globals(), globals())
    print(b)
if __name__ == '__main__':
    a = 5
    b = 6
    run()
 
值得一提的是,直接在__main__下不会发生以上情况,因为他们全是全局变量。
拓展
如果在类中,应该如何修改,将其成员化即可
class Net:
    def __init__(self):
        self.a = 5
        self.b = 6
    def run(self):
        exec("self.b = self.a")
        print(self.b)
if __name__ == '__main__':
    model = Net()
    model.run()
 
感谢及参考博文
部分内容参考以下链接,这里表示感谢 Thanks♪(・ω・)ノ
 参考博文1 官方Python API文档
 https://docs.python.org/zh-cn/3/
 参考博文2 Setting variables with exec inside a function
 https://stackoverflow.com/questions/23168282/setting-variables-with-exec-inside-a-function



















