1.问题发现
问题背景: 如下是我的文件夹目录,本项目入口文件是main.py,我们只需要关注Util里面的config.py和log.py,和外面的main.py三个文件。
问题: python main.py运行代码,main.py中from Util import config,log,没什么问题,但是config.py中import log报模块没找到。两个文件在一个目录下,为什么找不到呢?
2.问题解决
Python执行文件后,被执行的文件作为根目录,也作为包搜索路径。如图是打印出包路径,是个列表按照列表搜索。
我们import包会按照下面的列表路径挨个搜索,可以看到只有顶级路径。 所以我们在config中import log找不到,想到的有如下解决方式:
- 1.既然是按照顶级目录搜索,我们可以从顶级目录角度触发,import Util.log即可。缺点:依赖上级目录,当我们把包拿出来还需要修改路径,一些通用包应该是即开即用的,不应该依赖上级。 关键点:从顶级目录开始写
- 2.用绝对路径的方式,在config中sys得到本文件目录,然后直接绝对路径+log。 缺点:绝对路径和项目根路径混用 关键点:直接绝对路径
- 3.PYTHONPATH方式,PYTHONPATH是包搜索的路径,Python下载的通用库就是直接去配置好的路径中搜索包,我们可以直接把config所在目录配置到默认路径,import log就会直接搜索log。 缺点:大家都用这种方式,PYTHONPATH会包含很多路径 关键点:配置环境变量,这个方法类似于C语言在CMakelists配置头文件搜索路径,然后include就会去相应目录找,但是CMakelists是临时的不是一个全局宏。
echo $PYTHONPATH得到
/opt/rh/devtoolset-6/root/usr/lib64/python2.7/site-packages:/opt/rh/devtoolset-6/root/usr/lib/python2.7/site-package