python内置函数exec()和eval()区别

在Python中,eval() 和 exec() 都是内置函数,用于执行存储在字符串或对象中的Python代码,但它们之间也有一些区别。

eval()

语法:eval(expression, globals=None, locals=None)

  • expression:需要求值的字符串表达式。可以是一个有效的Python表达式、一个代码块或一个对象。
  • globals(可选):表示全局命名空间的字典。提供该参数可以在求值时使用指定的全局变量。
  • locals(可选):表示局部命名空间的字典。提供该参数可以在求值时使用指定的局部变量。

用途:eval()通常用于计算单个表达式的值,例如用户输入的数学表达式,执行后并返回表达式的值。

示例:

计算加法表方式

复制代码
number = 10
print(eval('number + 1'))
#结果
11

参数传一个字典,执行时会使用字典中的值

复制代码
number = 10
print(eval('number + 1',globals(),{'number':100}))
#结果
101

exec()

语法:exec(object[, globals[, locals]])

  • object:要执行的代码,可以是一个字符串或代码对象。
  • globals和locals与eval()中的含义相同。

用途:exec()通常用于动态执行一组Python代码,例如从文件中读取Python代码并执行,而且exec()执行后不返回值,只是执行代码。

示例:

#计算表达式的值

复制代码
eval(""" 
x = 1 
y = 2 
print(x + y) 
""")
#结果
3

#打开文件2.txt,获取代码,文件中代码如同上面执行的表达式

复制代码
exec(str(open('2.txt').readlines()))
#结果
3

#与complie函数结合使用

复制代码
code_object = compile(""" 
x = 1 
y = 2 
print(x + y) 
""", 'my_script', 'exec')
#传入complie对象
exec(code_object)

安全性考虑

使用eval()和exec()时要特别小心,因为它们可以执行任意的Python代码。如果这些函数执行的代码来自不可信的源(如用户输入),那么它们可能会被利用来执行恶意代码。

共勉: 东汉·班固《汉书·枚乘传》:"泰山之管穿石,单极之绠断干。水非石之钻,索非木之锯,渐靡使之然也。"

-----指水滴不断地滴,可以滴穿石头;

-----比喻坚持不懈,集细微的力量也能成就难能的功劳。

----感谢读者的阅读和学习和关注,谢谢大家。

相关推荐
每天回答3个问题11 分钟前
UE5C++编译遇到MSB3073
开发语言·c++·ue5
伍哥的传说24 分钟前
Vite Plugin PWA – 零配置构建现代渐进式Web应用
开发语言·前端·javascript·web app·pwa·service worker·workbox
这里有鱼汤25 分钟前
Python量化实盘踩坑指南:分钟K线没处理好,小心直接亏钱!
后端·python·程序员
小莞尔1 小时前
【51单片机】【protues仿真】 基于51单片机八路抢答器系统
c语言·开发语言·单片机·嵌入式硬件·51单片机
大模型真好玩1 小时前
深入浅出LangGraph AI Agent智能体开发教程(五)—LangGraph 数据分析助手智能体项目实战
人工智能·python·mcp
测试老哥1 小时前
Selenium 使用指南
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
我是菜鸟0713号1 小时前
Qt 中 OPC UA 通讯实战
开发语言·qt
JCBP_1 小时前
QT(4)
开发语言·汇编·c++·qt·算法
Brookty1 小时前
【JavaEE】线程安全-内存可见性、指令全排序
java·开发语言·后端·java-ee·线程安全·内存可见性·指令重排序
百锦再2 小时前
[特殊字符] Python在CentOS系统执行深度指南
开发语言·python·plotly·django·centos·virtualenv·pygame