python中的eval()和exec()函数

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time    : 2021/3/14 18:31
# @Author  : banzhu
# @File    : eval-exec.py
"""
eval()和exec()函数都可以用来执行一个字符串表达式,
不同的是,eval() 执行完要返回结果,而 exec() 执行完不返回结果
"""
# eval()语法格式:eval(expression, globals=None, locals=None)
# expression -- 表达式,这个参数是一个字符串,代表要执行的语句,只有在 globals和locals作用域内的函数和变量才能被执行
# globals -- 变量作用域,全局命名空间,如果被提供,则必须是一个字典对象。
# locals -- 变量作用域,局部命名空间,如果被提供,可以是任何映射对象。如果该参数被忽略,那么它将会取与globals相同的值。

x = 10
def func():
  y = 20
  a = eval('x + y')
  print('a: ', a)
  b = eval('x + y', {'x': 1, 'y': 2})
  print('b: ', b)
  c = eval('x + y', {'x': 1, 'y': 2}, {'y': 3, 'z': 4})
  print('c: ', c)
  d = eval('print(x, y)')
  print('d: ', d)
func()
# 输出结果:
# a:  30
# b:  3
# c:  4
# 10 20
# d:  None

"""
对于变量a,eval函数的globals和locals参数都被忽略了,因此变量x和变量y都取得的是eval函数被调用环境下的作用域中的变量值,即:x = 10, y = 20,a = x + y = 30

对于变量b,eval函数只提供了globals参数而忽略了locals参数,因此locals会取globals参数的值,即:x = 1, y = 2,b = x + y = 3

对于变量c,eval函数的globals参数和locals都被提供了,那么eval函数会先从全部作用域globals中找到变量x, 从局部作用域locals中找到变量y,即:x = 1, y = 3, c = x + y = 4

对于变量d,因为print()函数不是一个计算表达式,没有计算结果,因此返回值为None
"""

# exec()语法格式:exec(object[, globals[, locals]])
# object:必选参数,表示需要被指定的Python代码。它必须是字符串或code对象。如果object是一个字符串,该字符串会先被解析为一组Python语句,然后在执行(除非发生语法错误)。
# 如果object是一个code对象,那么它只是被简单的执行。
# globals:可选参数,同eval函数
# locals:可选参数,同eval函数
# exec函数的返回值永远为None

x = 10
def func():
  y = 20
  a = exec('x + y')
  print('a: ', a)
  b = exec('x + y', {'x': 1, 'y': 2})
  print('b: ', b)
  c = exec('x + y', {'x': 1, 'y': 2}, {'y': 3, 'z': 4})
  print('c: ', c)
  d = exec('print(x, y)')
  print('d: ', d)
func()
# 输出结果:
# a:  None
# b:  None
# c:  None
# 10 20
# d:  None

# eval()函数只能计算单个表达式的值,而exec()函数可以动态运行代码段。
x = 10
expr = """
z = 30
sum = x + y + z
print(sum)
"""
def func():
  y = 20
  exec(expr)
  exec(expr, {'x': 1, 'y': 2})
  exec(expr, {'x': 1, 'y': 2}, {'y': 3, 'z': 4})
func()
# 输出结果:
# 60
# 33
# 34

# 第三个结果34执行过程:
x = 1
y = 2
def func():
  y = 3
  z = 4
  z = 30
  sum = x + y + z
  print(sum)
func()
处在这个俗世,也得让自己变得更好吧
原文地址:https://www.cnblogs.com/butaileng7/p/14534300.html