资讯专栏INFORMATION COLUMN

Python之浅谈exec()函数

hedzr / 2300人阅读

摘要:本次分享讲简单聊聊函数的用法,希望能给读者一点启示和参考。在最后的语句中,我们给出了的值,并且值重复,函数接收后面一个值,且值传递不起作用,因此输出结果为本次分享到此结束。本文介绍了几个函数使用的例子,希望能抛砖引玉,也欢迎大家多多交流

  在Python中,exec()是一个十分有趣且实用的内置函数,不同于eval()函数只能执行计算数学表达式的结果的功能,exec()能够动态地执行复杂的Python代码,能够十分强大。具体的介绍可以参考官方文档: https://docs.python.org/3/lib... 。
  本次分享讲简单聊聊exec()函数的用法,希望能给读者一点启示和参考。
  首先是一个简单的小例子,代码如下:

i = 12
j = 13
exec("answer=i*j")
print("Answer is %s"%answer)

该代码的输出结果为:

Answer is 156

这表明第三句的exec()函数能够正确地执行Python代码,并且能将计算结果赋予answer变量,就像真正的Python代码一样。
  那么,我们能不能让exec()函数执行一个复杂的Python代码呢?Why not?请看一下例子:

func = "def fact(n):
	return 1 if n==1 else n*fact(n-1)"
exec(func)
a = fact(5)
print(a)

func为字符串,它是一个递归地计算整数阶乘的函数。因为exec()仅支持string和code object参数,所以我们要将该递归函数转化成一个字符串,当然,格式还是要Python代码的格式来,注意换行和缩进。刚才例子的输出结果为:

120

  可能有些读者纳了闷了,这些代码不是直接能够在Python中执行吗,为何还要多此一举地把它写成字符串,并用exec()执行呢?笔者的答案是,刚才的例子只是为了演示exec()函数的基本用法,它的强大之处远不止于此。
  在实际项目中,我们有些时候会将Python代码写入一些文件中,举个例子,如以下的eg.txt,它储存了我们想要的Python代码,如下:

def fact(n):
    if n==1:
        return 1
    else:
        return n*fact(n-1)
t = fact(6)
print(t)

请再次注意,这是一个txt格式的Python代码。那么,我们如何调用它呢?答案就是exec()函数,代码如下:

with open("E://eg.txt", "r") as f:
    s = f.read()

exec(s)

在上述代码中,我们先读取eg.txt文件的内容,再转交exec()函数执行,输出结果如下:

720

  是不是有点棒呢?除了能执行string和code object外,还可以在exec()函数中加入参数,参数的传递可以写成字典(dict)形式。具体的使用方法可以参考下面的例子:

x = 10

expr = """
z = 30
sum = x + y + z
print(sum)
"""

def func():
    y = 20
    exec(expr)
    exec(expr, {"x": 1, "y": 2})
    exec(expr, {"x": 1, "y": 2}, {"y": 3, "z": 4})

func()

其输出结果如下:

60
33
34

在expr语句中,有三个变量x,y,z,其中z值已给定,我们可以在exec()函数外指定x,y的值,也可以在exec()函数中以字典的形式指定x,y的值。在最后的语句中,我们给出了x,y,z的值,并且y值重复,exec()函数接收后面一个y值,且z值传递不起作用,因此输出结果为34.
  本次分享到此结束。本文介绍了几个exec()函数使用的例子,希望能抛砖引玉,也欢迎大家多多交流~~

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/41580.html

相关文章

  • Android安全开发浅谈密钥硬编码

    摘要:简介在阿里聚安全的漏洞扫描器中和人工安全审计中,经常发现有开发者将密钥硬编码在代码文件中,这样做会引起很大风险。阿里聚安全开发建议通过以上案例,并总结下自己平时发现密钥硬编码的主要形式有密钥直接明文存在文件中,这是最不安全的。 1 简介 在阿里聚安全的漏洞扫描器中和人工APP安全审计中,经常发现有开发者将密钥硬编码在Java代码、文件中,这样做会引起很大风险。信息安全的基础在于密码学,...

    zone 评论0 收藏0
  • React | 高效前端浅谈

    摘要:毫无疑问,作为近两年前端三大流行框架之一,正成为程序员们最喜爱的框架。自年月开源至今,已有千万网站使用来进行前端构架,使之成为最受欢迎的项目之一。经过这几年的沉淀,越来越强大,暂不提这几年在国内与之间的矛盾,这其中还有很大谈判空间。 showImg(https://segmentfault.com/img/bV0dY9?w=469&h=240); React在国外已被各个公司的各种产品...

    曹金海 评论0 收藏0
  • Python进阶笔记

    摘要:用匿名函数有个好处,因为函数没有名字,不必担心函数名冲突。和不同的是,把传入的函数依次作用于每个元素,然后根据返回值是还是决定保留还是丢弃该元素。字符串给出当前平台使用的行终止符。程序中间的退出,为正常退出。 列表生成式 函数的参数类型 lambda函数 map, reduce, filter, sorted函数 eval, exec, join, zip函数 itertools中的...

    ygyooo 评论0 收藏0
  • Android应用安全开发浅谈网页打开APP

    摘要:如果在中,没有检查获取到的的值,攻击者可以构造钓鱼网站,诱导用户点击加载,就可以盗取用户信息。阿里聚安全对开发者建议中任何接收外部输入数据的地方都是潜在的攻击点,过滤检查来自网页的参数。 一、网页打开APP简介 Android有一个特性,可以通过点击网页内的某个链接打开APP,或者在其他APP中通过点击某个链接打开另外一个APP(AppLink),一些用户量比较大的APP,已经通过发布...

    habren 评论0 收藏0
  • Android 应用安全开发浅谈加密算法的坑

    摘要:还有很多开发者没有意识到的加密算法的问题。不要使用哈希函数做为对称加密算法的签名。开发者建议使用基于口令的加密算法时,生成密钥时要加盐,盐的取值最好来自,并指定迭代次数。不要使用没有消息认证的加密算法加密消息,无法防重放。 本文作者:阿里移动安全@伊樵,@舟海 Android开发中,难免会遇到需要加解密一些数据内容存到本地文件、或者通过网络传输到其他服务器和设备的问题,但并不是使用了加...

    不知名网友 评论0 收藏0

发表评论

0条评论

hedzr

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<