发布时间:2019-09-26 12:29:09编辑:auto阅读(2286)
在进行模块化编程时,经常会遇到这样一种场景:
编写了一个 Python 模块,并用
import my_module
的形式进行导入。当对该模块进行更改后,即使重新导入,其中的任何改变都不会被识别,这使得模块调试变得非常困难。
那么,该如何解决这个问题?
| 版权声明:一去、二三里,未经博主允许不得转载。
出于效率原因(导入必须找到文件,将其编译成字节码,并且运行代码),Python shell 在每次会话中,只对每个模块导入一次。
例如,有一个名为 hello.py
的模块,包含以下代码:
print('Hello, Python!')
如果多次导入,会出现什么效果?
>>> import hello
Hello, Python!
>>>
>>> import hello
>>> import hello
可以看到,代码只执行了一次。也就是说,模块仅被导入了一次。
倘若,更改了已经在 Python shell 中导入的模块,然后重新导入该模块,Python 会认为“我已经导入了该模块,不需要再次读取该文件”,所以更改将无效。
要解决这个问题,有以下几种方式:
reload()
函数。在许多情况下,在编辑一个模块之后就足够了。PS: 下面主要介绍第 2 种方式 - reload()
,其他方式自行尝试。
reload()
是 Python 提供的一种简洁的方式,在不同的 Python 版本中有不同的表现形式:
>>> import importlib
>>> import hello
Hello, Python! # 修改前的内容
>>>
>>> importlib.reload(hello)
I am coming... # 修改后的内容
<module 'hello' from '/home/wang/Projects/hello.py'>
上一篇: python中的this——self
下一篇: python返回数组(list)长度的方
47750
46254
37136
34643
29233
25893
24762
19866
19428
17917
5720°
6324°
5843°
5892°
6993°
5831°
5851°
6365°
6319°
7684°