在 PyCharm 里正常运行的程序在CLI命令界面中运行失败,抛出 ImportError: No module named .. 错误。
原因是 PyCharm 会将当前工程根目录追加到 PYTHONPATH 变量,进而通过 sys.path 变量引导系统搜索当前目录下的模块,而系统CLI使用命令 python 执行脚本时,并没有自动追加工程根目录,导致导入包搜索失败。
解决方法从这里找到了:
https://stackoverflow.com/questions/37536832/python-run-importerrorno-module-named
复述一下解决思路,主要是通过本地安装,将项目(软链接)安装至系统 python 第三方模块目录下,从而根本上解决搜索路径问题。
假设项目目录如下:
ProjectName/
├── setup.py
├── project_name/
├── __init__.py
├── program.py
├── module_a.py
└── module_b.py
首先需要为项目建立一个 setup.py 脚本,用于引导安装过程,指定程序入口等,内容格式大概如下:
from setuptools import setup, find_packages
setup(
name=PROJECT_NAME, # 填入合适的名字,下同
version=VERSION,
author=AUTHOR,
package=find_packages(),
install_requires=['docopt'], # 这里填入该项目依赖的所有第三方模块
entry_points={
'console_scripts': [
'command_name = project_name.program:main' # 这里的各个字段需要改为当前项目匹配名字
# command_name 指定一个启动当前程序的命令名
# 该命令触发当前项目根目录下 project_name 目录中名为 program 模块内的 main 函数
]
}
)
然后在项目根目录下执行 pip install -e .
命令(推荐在 virtualenv 环境下操作),该项目即以 egg-link 形式创建到 python 目录中,并保持与当前项目代码同步更新。
现在开始可以通过之前设定的 command_name 调用程序。
除了上述方法以外,也可以通过在项目根目录下建立一个临时入口脚本,调用真正需要执行的次级包脚本、函数,通过 CLI 调用项目根目录下的该临时入口脚本不会产生 ImportError 问题。
最后也可以尝试修改系统变量方式解决(未验证)。