【python】bug:lost sys.stdout
舍友X神今天问了我一个bug:
挺新奇的, 第一次见。
看到他设的文件名abc, 想起来以前调用的模块abc
让他修改文件名为abcd,成功运行了
为了了解一下这个bug的原理, 我又上网查了一些博客
原来是给文件的命名和python中的内置模块名一样。
我又取了io.py,print.py,果然会出这种bug
原理也很简单:
python在搜寻包的时候会先搜寻项目内有没有该模块,
如果有就用项目内的模块,如果没有就到称为sys.path的list中寻找,所有的python自带的模块和pip安装第三方模块都在这里。
如何避免:
根据上述结论,我们可以得到一个很简单的避免方法——既然命名和模块相同会产生这样的错误,那么我们在命名的时候只要规避这些模块名就不会出现这样的错误。
这就引出了python文件命名的规范——不要用模块名命名py文件