导入LIB不使用EXEC功能?

Import Lib not working with exec function?(导入LIB不使用EXEC功能?)
本文介绍了导入LIB不使用EXEC功能?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我已经编写了以下代码字符串,并尝试通过exec方法执行它。仅在全局模式下运行此代码时,它运行正常。

codeRule = """import math
def fun (n):
    data = n
    data = data * math.pi
    print(data)
    return data
dd = fun(n)"""
    
codeObejct = compile(codeRule, 'sumstring', 'exec')
exec(codeObejct, dict(n = 10))

但我的用例需要dd值在exec之外,所以我使用下面的参数在另一个数据帧内获取dd值。

loc = {}
exec(codeObejct, dict(n = 10), loc)
dd = loc["dd"]

但只要我使用local,它就开始给我一个关于lib导入的错误,如

File "<stdin>", line 1, in <module>
  File "sumstring", line 7, in <module>
  File "sumstring", line 4, in fun
NameError: name 'math' is not defined

有人能帮我解决这个问题吗?

我已经检查了以下问题的答案,但我不知道如何将其应用到我的用例中。

Why doesn't an import in an exec in a function work?

推荐答案

最终,我得到了解决方案,

我在exec中漏掉了一分。以下是我得到的解决方案,我希望它适用于我的实际用例

codeRule = """import math
def fun (n):
    data = n
    data = data * math.pi
    return data
"""
#export Function 
exec (codeRule, globals())

dd = fun(10)
dd
31.41592653589793

这篇关于导入LIB不使用EXEC功能?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Leetcode 234: Palindrome LinkedList(Leetcode 234:回文链接列表)
How do I read an Excel file directly from Dropbox#39;s API using pandas.read_excel()?(如何使用PANDAS.READ_EXCEL()直接从Dropbox的API读取Excel文件?)
subprocess.Popen tries to write to nonexistent pipe(子进程。打开尝试写入不存在的管道)
I want to realize Popen-code from Windows to Linux:(我想实现从Windows到Linux的POpen-code:)
Reading stdout from a subprocess in real time(实时读取子进程中的标准输出)
How to call type safely on a random file in Python?(如何在Python中安全地调用随机文件上的类型?)