Python脚本在PyCharm中运行,但不在Git Bash中运行

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (2)
  • 关注 (0)
  • 查看 (429)

假设我有一个任意大的模块化Python 2.7代码库:

project
↳ docs
↳ etc
↳ package
  ↳ module1
    ↳ submodule1
      ↳ subsubmodule1
        ↳ __init__.py
      ↳ subsubmodule2 (... and so on)
      ↳ __init__.py
    ↳ submodule2
      ↳ subsubmodule1
        ↳ __init__.py
      ↳ subsubmodule2 (... and so on)
      ↳ __init__.py
    ↳ submodule3 (... and so on)
      ↳ __init__.py
  ↳ module2
    ↳ submodule1
      ↳ __init__.py
    ↳ submodule2 (... and so on)
      ↳ __init__.py
    ↳ __init__.py        
  ↳ module3 (... and so on)
    ↳ __init__.py
  ↳ __init__.py
↳ test
  • project 是根文件夹 - 它是一个PyCharm项目,它不是一个模块。
  • project\package是项目的根Python模块。它包含许多子目录,每个子目录都是一个名为的Python模块moduleN
  • 每个project\package\moduleN模块都包含许多子目录,每个子目录都是一个名为submoduleN... 的Python模块,依此类推。

假设我有一个特定的Python脚本foo.py,我希望运行它,并且它位于以下无限多个子模块中的一个子模块中package

# foo.py:

from package.module2.submodule3 import foo
print foo.bar()

当从PyCharm运行脚本时Ctrl+F9:没问题,foo.bar()打印。

但是当脚本从Git Bash终端运行时,从主目录运行:

python path/to/project/package/module4/submodule6/subsubmobile5/foo.py

抛出以下错误:

ImportError:没有名为package.module2.submodule3的模块

我想知道我需要做什么才能让我的脚本在Git Bash上运行,以及为什么PyCharm和Git Bash之间首先出现差异。这与它有关PYTHONPATH吗?

编辑

  • 许多 StackOverflow答案建议使用一些sys.path.append()黑客的迭代。在我的案例中,这些建议都不起作用。
  • 我设置了一个.bashrc文件export PYTHONPATH=absolute/path/to/project/packagepackage在PyCharm中我的源根目录在哪里,但仍然会抛出导入错误。相对路径也不起作用。我已经验证了路径是正确的echo $PYTHONPATHexport PYTHONPATH=absolute/path/to/project同样不起作用。
  • 工作目录似乎并不重要 - 无论工作目录如何,Git Bash每次都失败,并且PyCharm每次都工作,无论工作目录如何。

编辑2

这个问题仍未得到解决,但可能与PYTHONPATHGit Bash上未正确设置有关。如果Add Content Roots to PYTHONPATH取消选中,PyCharm抛出同样的导入错误的混帐击。

提问于
用户回答回答于

注意:如果您的应用程序/库具有第三方依赖项,则下面公开的解决方案将不起作用。为此,你需要一个virtualenv。看我以前的回答

您具有以下树结构path\to\project

path\to\project
├───docs
├───etc
├───package
│   │   __init__.py
│   ├───module1 [...]
│   ├───module2
│   │   │   __init__.py
│   │   ├───submodule1 [...]
│   │   ├───submodule2 [...]
│   │   └───submodule3
│   │           foo.py
│   │           __init__.py
│   ├───module3 [...]
│   └───module4
│       │   __init__.py
│       └───submodule6
│           │   __init__.py
│           └───subsubmobile5
│                   foo.py
│                   __init__.py
└───tests

这里package是项目的根Python包,path\to\project是项目源目录(PyCharm使用的目录)。

要在此包中运行脚本,例如脚本package/module4/submodule6/subsubmobile5/foo.py,您需要将项目设置PYTHONPATH为根,即path\to\project

但是,由于您使用的是Windows并运行Git Bash,因此需要使用正斜杠将Windows路径转换为有效的Linux路径。

一种方法是:

$ export PYTHONPATH=path/to/project && python path/to/project/package/module4/submodule6/subsubmobile5/foo.py

你甚至可以执行模块package.module4.submodule6.subsubmobile5.foo

$ export PYTHONPATH=path/to/project && python -m package.module4.submodule6.subsubmobile5.foo
用户回答回答于

解决问题的正确方法不是破解PYTHONPATH,因为如果您的库/应用程序具有第三方依赖项,这将无用。

为了正常工作,PyCharm使用了两件事:

  • 源根(添加到PYTHONPATH),和,
  • 项目口译员(即virtualenv),

要检查,请在PyCharm中打开终端视图,然后尝试:

$ python
>>> import sys
>>> for p in sys.path:
...     print(p)
...

正确的方法是使用virtualenv

要在Windows上创建virtualenv,请转到要创建virtualenv的目录。它可以位于一个唯一的目录中(如pew推荐),也可以位于项目目录中(通常位于.venv)。

virtualenv -p C:\Python27\python.exe yourvenv

然后,激活您的virtualenv并在开发/可编辑模式下安装您的应用程序:

yourvenv\Scripts\activate

cd path\to\project\
pip install -e .

在这里,您已经安装了库/应用程序及其所有依赖项。该-e标志表示“可编辑”(与旧的“开发”模式匹配),请参阅pip文档。

每当您想要运行脚本时,您可以执行以下操作:

yourvenv\Scripts\activate
python -m package.module4.submodule6.subsubmobile5.foo

在Windows上,您还可以:

yourvenv\Scripts\activate
python path\to\project\package\module4\submodule6\subsubmobile5\foo.py

在Git bash上,您可以:

source yourvenv/Scripts/activate
python path/to/project/package/module4/submodule6/subsubmobile5/foo.py

如果要从另一批中调用Python脚本,可以执行以下操作:

yourvenv/Scripts/python.exe -m package.module4.submodule6.subsubmobile5.foo
yourvenv/Scripts/python.exe path/to/project/package/module4/submodule6/subsubmobile5/foo.py

扫码关注云+社区

领取腾讯云代金券