【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文件

 

posted @ 2022-02-20 20:43  鱼儿冒个泡  阅读(44)  评论(0编辑  收藏  举报