简介
eval函数跟强制转换变量类型的方法差不多,如int()、float(),区别只是eval函数还会再去按python语法执行一遍。
代码解释
# eval函数经常跟input函数一起使用(因为input函数输入的是字符串,所以需要用eval函数去掉字符串的引号)
# eval函数是去掉字符串的引号,然后按python语法执行
age = eval(input('请输入年龄:')) #18
print(age,type(age))
sum = eval(input('输入数字:')) #5+6
print(sum,type(sum))
# 场景1:动态计算用户输入的表达式
result = eval(input("输入一个数学表达式(如 5+3*2):"))
print("结果是:", result,type(result))
# 场景2:将字符串转换为数值类型。如果字符串是 "3.14",eval 会转为浮点数;如果是 "True",转为布尔值。
age_str = "25"
age = eval(age_str) # 转换为整数 25
'''
风险警告
1. 安全性问题:
eval() 会直接执行字符串中的代码,不可用于处理不可信的输入。
例如,如果用户输入 os.remove("/path/to/file")(假设导入了 os),会直接删除文件!
2. 替代方案:
如果只需将字符串转为数字或数据结构,可用 int()、float() 或 ast.literal_eval()(更安全,仅处理纯数据)。
'''