setuptools:load_entry_point上的ImportError

问题描述 投票:0回答:1

我正在尝试在安装我的包时创建一个入口点。这是我的包裹:

.
├── foo
│   ├── example.py
│   └── __init__.py
└── setup.py

我的setup.py是:

import sys
from setuptools import setup, find_packages


console_scripts = \
    ['foo.py = foo.example:main']

setup(name='foo',
      version='1.1.1',
      author='me',
      author_email='me',
      url='',
      entry_points={'console_scripts': console_scripts},
      include_package_data=True,
      packages=find_packages(),
      zip_safe=False)

这是example.py:

def main():
    print "hello world"

我这样安装:

python setup.py sdist
pip install dist/foo-1.1.1.tar.gz

它工作正常。但是当我尝试使用入口点/usr/bin/foo.py时,我得到了这个回溯:

Traceback (most recent call last):
  File "/usr/bin/foo.py", line 11, in <module>
    load_entry_point('foo==1.1.1', 'console_scripts', 'foo.py')()
  File "/usr/lib/python2.7/site-packages/pkg_resources/__init__.py", line 570, in load_entry_point
    return get_distribution(dist).load_entry_point(group, name)
  File "/usr/lib/python2.7/site-packages/pkg_resources/__init__.py", line 2751, in load_entry_point
    return ep.load()
  File "/usr/lib/python2.7/site-packages/pkg_resources/__init__.py", line 2405, in load
    return self.resolve()
  File "/usr/lib/python2.7/site-packages/pkg_resources/__init__.py", line 2411, in resolve
    module = __import__(self.module_name, fromlist=['__name__'], level=0)
ImportError: No module named example

在python shell中导入foo模块也可以正常工作。

python python-2.7 setuptools setup.py entry-point
1个回答
1
投票

您将入口点脚本命名为foo.py。当你运行它时,从脚本中导入foo导入。也就是说,你遮蔽了你的包foo。该脚本没有子模块example因此错误。

不要命名脚本foo.py,将其命名为foo

console_scripts = \
    ['foo = foo.example:main']

或者如果你需要bar.py扩展名,请将其命名为.py。那样它就不会影子包foo

© www.soinside.com 2019 - 2024. All rights reserved.