转自:http://blog.csdn.net/turkeyzhou/article/details/8846527  

    reload()内建函数可以重新导入一个已经全部被成功导入的模块,reload()函数的参数必须是模块自身。模块中的代码在导入时被执行,但是只执行一次,以后执行Import时不会在执行这些代码,只是绑定模块名称。

   

    reload会重新加载已加载的模块,但原来已经使用的实例还是会使用旧的模块,而新生产的实例会使用新的模块;reload后还是用原来的内存地址;不能支持from。。import。。格式的模块进行重新加载。
测试:

[python] view plain copy 
  1. a.py 

  2. #!/usr/bin/env python 

  3. #encoding: utf-8

  4. import os 

  5. print'in a',id(os) 

  6. m.py 

  7. #!/usr/bin/env python 

  8. #encoding: utf-8

  9. import a #第一次import会打印a里面的语句

  10. print id(a) #原来a的内存地址

  11. reload(a) #第二次reload还会打印a里面的语句,因为有重新加载

  12. print id(a) #reload后a的内存地址,和原来一样

扩展:
上面说了,在特殊情况的下才会使用reload函数;除了原来模块文件有修改外,还有哪些情况需要使用reload函数呢,这里举个例子。
[python] view plain copy 
  1. #!/usr/bin/env python 

  2. #encoding: utf-8

  3. import sys #引用sys模块进来,并不是进行sys的第一次加载

  4. reload(sys) #重新加载sys

  5. sys.setdefaultencoding('utf8'##调用setdefaultencoding函数

上面的代码是正确的,再测试下面的代码
[python] view plain copy 
  1. #!/usr/bin/env python 

  2. #encoding: utf-8

  3. import sys 

  4. sys.setdefaultencoding('utf8'

上面的测试会失败,那么为什么要在调用setdefaultencoding时必须要先reload一次sys模块呢?因为这里的import语句其实并不是sys的第一次导入语句,也就是说这里其实可能是第二、三次进行sys模块的import,这里只是一个对sys的引用,只能reload才能进行重新加载;那么为什么要重新加载,而直接引用过来则不能调用该函数呢?因为setdefaultencoding函数在被系统调用后被删除了,所以通过import引用进来时其实已经没有了,所以必须reload一次sys模块,这样setdefaultencoding才会为可用,才能在代码里修改解释器当前的字符编码。试试下面的代码,同样会报错:

 

[python] view plain copy 
  1. #!/usr/bin/env python 

  2. #encoding: utf-8

  3. import sys 

  4. reload(sys) 

  5. sys.setdefaultencoding('utf8'

  6. del sys.setdefaultencoding ##删除原来的setdefaultencoding函数 

  7. sys.setdefaultencoding('gb2312'

 

那么到底是谁在之前就导入sys并且调用了setdefaultencoding函数呢?答案就在python安装目录的Lib文件夹下,有一个叫site.py的文件【python2.6】,在里面可以找到main() --> setencoding()-->sys.setdefaultencoding(encoding),因为这个site.py每次启动python解释器时会自动加载,所以main函数每次都会被执行,setdefaultencoding函数一出来就已经被删除了。