Pip 列表显示包已安装但导入包抛出 ImportError

Jos*_*osh 6 python pip setuptools

我的 VCS 中有一个托管包。我跑:

$ pip install -vvv git+https://myvcs.com/myprotos
Run Code Online (Sandbox Code Playgroud)

这是日志。您会注意到它在安装过程中运行一个自定义脚本,该脚本实际上在项目中构建源文件。有关它正在做什么的详细信息,请参阅此问题。

Collecting git+https://myvcs.com/myprotos
  Cloning https://myvcs.com/myprotos to /private/var/folders/3t/4qwkfyr903d0b7db7by2kj6r0000gn/T/pip-cFzP3I-build
  Running command git clone -q https://myvcs.com/myprotos /private/var/folders/3t/4qwkfyr903d0b7db7by2kj6r0000gn/T/pip-cFzP3I-build
  Running setup.py (path:/private/var/folders/3t/4qwkfyr903d0b7db7by2kj6r0000gn/T/pip-cFzP3I-build/setup.py) egg_info for package from git+https://myvcs.com/myprotos
    Running command python setup.py egg_info
    running egg_info
    creating pip-egg-info/myprotos.egg-info
    writing pip-egg-info/myprotos.egg-info/PKG-INFO
    writing top-level names to pip-egg-info/myprotos.egg-info/top_level.txt
    writing dependency_links to pip-egg-info/myprotos.egg-info/dependency_links.txt
    writing manifest file 'pip-egg-info/myprotos.egg-info/SOURCES.txt'
    reading manifest file 'pip-egg-info/myprotos.egg-info/SOURCES.txt'
    writing manifest file 'pip-egg-info/myprotos.egg-info/SOURCES.txt'
  Source in /private/var/folders/3t/4qwkfyr903d0b7db7by2kj6r0000gn/T/pip-cFzP3I-build has version 0.0.1, which satisfies requirement myprotos==0.0.1 from git+https://myvcs.com/myprotos
Installing collected packages: myprotos
  Running setup.py install for myprotos: started
    Running command /usr/local/opt/python/bin/python2.7 -u -c "import setuptools, tokenize;__file__='/private/var/folders/3t/4qwkfyr903d0b7db7by2kj6r0000gn/T/pip-cFzP3I-build/setup.py';f=getattr(tokenize, 'open', open)(__file__);code=f.read().replace('\r\n', '\n');f.close();exec(compile(code, __file__, 'exec'))" install --record /var/folders/3t/4qwkfyr903d0b7db7by2kj6r0000gn/T/pip-M03grb-record/install-record.txt --single-version-externally-managed --compile
    running install
    Grabbing github.com/google/protobuf...
    Building Python protos...
    running build
    running install_egg_info
    running egg_info
    creating myprotos.egg-info
    writing myprotos.egg-info/PKG-INFO
    writing top-level names to myprotos.egg-info/top_level.txt
    writing dependency_links to myprotos.egg-info/dependency_links.txt
    writing manifest file 'myprotos.egg-info/SOURCES.txt'
    reading manifest file 'myprotos.egg-info/SOURCES.txt'
    writing manifest file 'myprotos.egg-info/SOURCES.txt'
    Copying myprotos.egg-info to /usr/local/lib/python2.7/site-packages/myprotos-0.0.1-py2.7.egg-info
    running install_scripts
    writing list of installed files to '/var/folders/3t/4qwkfyr903d0b7db7by2kj6r0000gn/T/pip-M03grb-record/install-record.txt'
    Running setup.py install for myprotos: finished with status 'done'
  Removing source in /private/var/folders/3t/4qwkfyr903d0b7db7by2kj6r0000gn/T/pip-cFzP3I-build
Successfully installed myprotos-0.0.1
Cleaning up...
Run Code Online (Sandbox Code Playgroud)

这样看来一切都安装成功了。甚至运行pip list输出:

$ pip list
.
.
.
myprotos (0.0.1)
.
.
.
Run Code Online (Sandbox Code Playgroud)

但是,如果我尝试导入包,它会抛出 ImportError 。

$ python
Python 2.7.13 (default, Jul 18 2017, 09:17:00)
[GCC 4.2.1 Compatible Apple LLVM 8.1.0 (clang-802.0.42)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>> import myprotos
Traceback (most recent call last):

  File "<stdin>", line 1, in <module>
ImportError: No module named myprotos
Run Code Online (Sandbox Code Playgroud)

这里可能发生了什么?构建脚本是否可能在安装时失败,或者我的包定义错误或者可能是什么?

Sve*_*ach 4

Egg 的名称不一定与其提供的模块或包的名称相同。事实上,这些名称不同是很常见的。一个egg可以包含多个包,所以一般情况下不可能使用相同的名称。此外,egg 名称可以包含破折号和 Python 模块名称中不允许的其他字符。

myprotos.egg-infoPython 目录中的目录应site-packages包含一个名为 的文件,top_level.txt该文件列出了所有顶级模块并打包了 Egg 导出。