python函数每日一讲 - eval函数

kkkkk 2018年12月17日 23:07 Python函数

函数定义:

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

将字符串str当成有效的表达式来求值并返回计算结果。globals和locals参数是可选的,如果提供了globals参数,那么它必须是dictionary类型;如果提供了locals参数,那么它可以是任意的map对象。

python的全局名字空间存储在一个叫globals()的dict对象中;局部名字空间存储在一个叫locals()的dict对象中。我们可以用print (locals())来查看该函数体内的所有变量名和变量值。

Python版本兼容:

Python2.7

Python3.x

eval()主要作用:

1)在编译语言里要动态地产生代码,基本上是不可能的,但动态语言是可以,意味着软件已经部署到服务器上了,但只要作很少的更改,只好直接修改这部分的代码,就可立即实现变化,不用整个软件重新加载。

2)在machin learning里根据用户使用这个软件频率,以及方式,可动态地修改代码,适应用户的变化。

英文解释:

The arguments are a string and optional globals and locals. If provided, globals must be a dictionary. If provided, locals can be any mapping object.


The expression argument is parsed and evaluated as a Python expression (technically speaking, a condition list) using the globals and locals dictionaries as global and local namespace. If the globals dictionary is present and lacks ‘__builtins__’, the current globals are copied into globals before expression is parsed. This means that expression normally has full access to the standard builtins module and restricted environments are propagated. If the locals dictionary is omitted it defaults to the globals dictionary. If both dictionaries are omitted, the expression is executed in the environment where eval() is called. The return value is the result of the evaluated expression. Syntax errors are reported as exceptions. Example:


例子:

a=1
g={'a':20}
eval("a+1",g)

结果:

21


例子2, 测试globals, locals

x = 1
y = 1
num1 = eval("x+y")
print (num1)
def g():    
    x = 2    
    y = 2  
    num3 = eval("x+y")    
    print (num3)        
    num2 = eval("x+y",globals())   
    #num2 = eval("x+y",globals(),locals())    
    print (num2)
    
g()

num1的值是2;num3的值也很好理解,是4;num2的值呢?由于提供了globals()参数,那么首先应当找全局的x和y值,也就是都为1,那么显而易见,num2的值也是2。如果注释掉该句,执行下面一句呢?根据第3)点可知,结果为4


安全问题:

因为eval的特型, 很可能被黑客利用,造成安全问题。

怎么避免安全问题?

1、自行写检查函数;

2、使用ast.literal_eval代替


文章评论(0)
  • avatar kkkkkk 2018年12月21日 11:31
    太假了吧!
    kkkkk
    2018年12月21日 11:16
    本文标题即是中心,针对现状提出观点,纵横捭阖而旗帜鲜明。将“互联网+慈善”的意义上升到一个民族的价值选择和中华民族传统精神传承延续的高度并深入入到人性内在需求的深度,见解深刻。联系国外情况进行辩证分析,阐述其完善需要假以时日,视野开阔。诸多引用体作者其丰厚学养。
    回复
  • avatar kkkkkk 2018年12月21日 11:31
    python学院最帅的是谁啊?
    kkkkklxinde
    2018年12月21日 11:17
    本文立意正确,紧扣材料说理,观点鲜明而集中,能简练概述作文材料,表达流畅而简洁,体现了较强的语言驱遣能力。比喻、说理等多种方法的运用,使论证具有说服力。诸多引用尤为精彩,体现了作者一定的学养。
    回复
  • avatar kkkkklxinde 2018年12月21日 11:17
    本文立意正确,紧扣材料说理,观点鲜明而集中,能简练概述作文材料,表达流畅而简洁,体现了较强的语言驱遣能力。比喻、说理等多种方法的运用,使论证具有说服力。诸多引用尤为精彩,体现了作者一定的学养。
    回复
  • avatar kkkkk 2018年12月21日 11:16
    本文标题即是中心,针对现状提出观点,纵横捭阖而旗帜鲜明。将“互联网+慈善”的意义上升到一个民族的价值选择和中华民族传统精神传承延续的高度并深入入到人性内在需求的深度,见解深刻。联系国外情况进行辩证分析,阐述其完善需要假以时日,视野开阔。诸多引用体作者其丰厚学养。
    回复