文章目录
- 1. 基本概念
- 2. 使用举例
- 3. eval 函数运用—— 计算器
- 4. 不要滥用 eval()
1. 基本概念
- eval() 是 python 中功能非常强大的一个函数
- 将字符串当成有效的表达式来求值,并返回计算结果
- 所谓表达式就是:
eval 这个函数会把里面的字符串参数的引号去掉,把中间的内容当成Python的代码
,eval 函数会执行这段代码并且返回执行结果 - 也可以这样来理解:eval() 函数就是实现 list、dict、tuple、与str 之间的转化
- 安全性是 eval 最大的缺点
2. 使用举例
1 基本的数学运算
# 1. 基本的数学运算 result = eval("1 + 1")print(result)# 2
2 字符串重复
# 2. 字符串重复result = eval("'+' * 5")print(result)# +++++
3 将字符串转换成列表
# 3. 将字符串转换成列表a = "[1, 2, 3, 4]"result = type(eval(a))print(result)#
4 将字符串转换成字典
result = type(eval("{'name': '小夏', 'age': 30}"))print(result)#
3. eval 函数运用—— 计算器
要求:
~~~~~~ 1.提示用户输入一个加减乘除混合运算
~~~~~~ 2.返回计算结果
代码:
input_number = input("请输入一个加减乘除运算公式:")print(eval(input_number))
执行结果:
4. 不要滥用 eval()
- 在开发时千万不要使用
eval直接转换input
的结果 - 因为如果用户直接通过os这个模块来调用system方法可以执行任何的终端命令,这样细想很恐怖,家底都给暴露出来了