1、关于setdefaultencoding之前必须reload(sys):
要在调用setdefaultencoding时必须要先reload一次sys模块,因为这里的import语句其实并不是sys的第一次导入语句,也就是说这里其实可能是第二、三次进行sys模块的import,这里只是一个对sys的引用,只能reload才能进行重新加载。
那么为什么要重新加载,而直接引用过来则不能调用该函数呢?因为setdefaultencoding函数在被系统调用后被删除了,所以通过import引用进来时其实已经没有了,所以必须reload一次sys模块,这样setdefaultencoding才会为可用,才能在代码里修改解释器当前的字符编码。
在Python安装目录的Lib文件夹下,有一个叫site.py的文件,在里面可以找到main() --> setencoding()-->sys.setdefaultencoding(encoding),因为这个site.py每次启动python解释器时会自动加载,所以main函数每次都会被执行,setdefaultencoding函数一出来就已经被删除了。
2、log模块,日志重复打印的坑:
原因是,添加了多个handler。
解决办法:在每次添加之前清空handler:self.logger.handlers = []
参考网址:http://www.cnblogs.com/wswang/p/6138304.html
http://python.jobbole.com/86887/
http://www.jianshu.com/p/25f70905ae9d
3、urllib2
需要添加header等参数时要使用这个,先创建一个request对象。再使用urllib2.urlopen去发送请求。
当需要使用代理或者cookie时,要创建opener对象。这时有2种方式:
1)先install_opener,相当于一个全局的opener对象,后面的代码中就可以使用urllib2.urlopen来发送请求。
2)直接使用opener.open来发送请求。
4、package包下载地址
http://www.lfd.uci.edu/~gohlke/pythonlibs/#imread