不踩坑的Python爬虫,reload函数用法

一、python2和python3的区别

python2中可以直接使用reload()

python3中需要从库中导入,有两种方法:

>>> from imp import reload

>>> reload(moudle)

import imp

imp.reload(moudle)


二、在reload之前要import

reload函数是使用模块名称,而不是变量名称,也就是说当你把它改变了名称,它也是加载原来的名称。#极光ip# 动态ip一键切换[大侦探皮卡丘微笑]

当使用reload时,这个模块会被重新编译,新的模块替换原来的模块。如果之前从这个模块创建的实例仍然使用旧的模块实现。特别是使用from-import语句加载的名称,也不会被更新。

例如图一


不踩坑的Python爬虫,reload函数用法

图一

输出如图二


不踩坑的Python爬虫,reload函数用法

图二

这里helo.py代码如下:

print('hello again, and welcome to the show')


三、总结

1. 如果模块在语法上是正确的,但在初始化过程中失败,则导入过程不能正确地将模块的名字绑定到符号表中。这时,必须在模块能被重新加载之前使用import()函数加载该模块。

2. 重新加载的模块不删除最初旧版本模块在符号表中的登记项。

3. 如果一模块利用from。。。import。。。方式从另一模块导入对象,reload()函数不重新定义导入的对象,可利用import。。。形式避免这个问题。

4. 提供类的重新加载模块不影响所提供类的任何已存实例---已存实例将继续使用原来的方法定义,只有该类的新实例使用新格式。这个原则对派生类同样适用。


分享到:


相關文章: