python内置函数eval(x)的作用_python eval()内置函数

python有一个内置函数eval(),可以将字符串进行运行。

通过help(eval)查看帮助文档

Help on built-in function eval inmodule builtins:

eval(source, globals=None, locals=None, /)

Evaluate the given sourcein the context of globals andlocals.

The source may be a string representing a Python expressionora code object as returned by compile().

The globals must be a dictionaryandlocals can be any mapping,

defaulting to the current globalsandlocals.

If only globalsis given, locals defaults to it.

eval(source,globals=None,locals= None)

eval()函数默认是没有globals,locals,

如果提供则globals属性必须是一个字典dict类型,而locals 可以是任意映射

一般使用input函数,是str类型,如果进行数值运算,需要进行类型转化

a = input("Enter a number:\n")

从键盘输入一个数值

a = 2

type(a)

为str类型

而 使用eval()内置函数

a = eval(input("enter a number:\n"))

type(a)

则为int。

eval()函数可以将字符串str当成有效的表达式来求值并返回计算结果

昨天学习碰见一个题目,给做错了,现在记录一下。

number = eval(‘5‘+‘1*2‘) # 7是错误,正确答案是102

想当然的选择了答案是7,这个是错误的。

正确答案是:102.

因为这个eval()函数内有两个字符串"5"和"1*2",所以括号内首先做字符串连接,变成一个新的字符串"51*2",eval去掉双引号后,才能进行算数运算,得到数字102

再举个例子

number2 = eval(‘1‘+‘2*3‘+‘4*5‘)

# number2的值

print(number2)

2040

先拼接字符串,"12 *34*5"然后再去掉双引号进行算数运算,得到12*34*5=2040

eval()有一个坏处就是不太安全,如果用户输入一些字符串是恶意代码,则对系统不好,则需要使用

使用ast.literal_eval,

这个目前还没有用到,后续研究后进行总结。

原文地址:https://www.cnblogs.com/hamish26/p/10168088.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值