【发布时间】:2010-09-23 02:30:30
【问题描述】:
我正在开发一个名为“lehmer”的 Python 包,其中包含一堆用 C 编写的扩展模块。目前,我有一个扩展模块“rng”。我正在使用 Python 的 Distutils 来构建和安装模块。我可以编译和安装模块,但是当我尝试使用import lehmer.rng 或from lehmer import rng 导入模块时,Python 解释器会抛出ImportError 异常。我可以很好地导入“lehmer”。
这是我的setup.py 文件的内容:
from distutils.core import setup, Extension
exts = [Extension("rng", ["lehmer/rng.c"])]
setup(name="lehmer",
version="0.1",
description="A Lehmer random number generator",
author="Steve Park, Dave Geyer, and Michael Dippery",
maintainer="Michael Dippery",
maintainer_email="mpd@cs.wm.edu",
packages=["lehmer"],
ext_package="lehmer",
ext_modules=exts)
当我列出 Python 的 site-packages 目录的内容时,我看到以下内容:
th107c-4 lehmer $ ls /scratch/usr/lib64/python2.5/site-packages/lehmer
__init__.py __init__.pyc rng.so*
我的PYTHONPATH 环境变量设置正确,所以这不是问题(如前所述,我可以import lehmer 很好,所以我知道 PYTHONPATH 不是问题)。 Python 使用以下搜索路径(由sys.path 报告):
['', '/scratch/usr/lib64/python2.5/site-packages', '/usr/lib/python25.zip', '/usr/lib64/python2.5', '/usr/lib64/python2.5/plat-linux2', '/usr/lib64/python2.5/lib-tk', '/usr/lib64/python2.5/lib-dynload', '/usr/lib64/python2.5/site-packages', '/usr/lib64/python2.5/site-packages/Numeric', '/usr/lib64/python2.5/site-packages/PIL', '/usr/lib64/python2.5/site-packages/SaX', '/usr/lib64/python2.5/site-packages/gtk-2.0', '/usr/lib64/python2.5/site-packages/wx-2.8-gtk2-unicode', '/usr/local/lib64/python2.5/site-packages']
更新
在 OpenSUSE 10 机器上使用时可以工作,但在 Mac OS X 上测试时仍然无法加载 C 扩展。以下是 Python 解释器的结果:
>>> sys.path
['', '/usr/local/lib/python2.5/site-packages', '/opt/local/lib/python25.zip', '/opt/local/lib/python2.5', '/opt/local/lib/python2.5/plat-darwin', '/opt/local/lib/python2.5/plat-mac', '/opt/local/lib/python2.5/plat-mac/lib-scriptpackages', '/opt/local/lib/python2.5/lib-tk', '/opt/local/lib/python2.5/lib-dynload', '/opt/local/lib/python2.5/site-packages']
>>> from lehmer import rng
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ImportError: cannot import name rng
>>> import lehmer.rngs
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ImportError: No module named rngs
>>> import lehmer.rng
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ImportError: No module named rng
>>> from lehmer import rngs
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ImportError: cannot import name rngs
【问题讨论】:
-
其实你并不知道PYTHONPATH设置正确。您的本地目录始终位于 sys.path 列表的首位。你能运行 Python 并运行 'import sys;打印 sys.path` 并将其添加到您的问题中?
-
抱歉这个愚蠢的问题,但是 ImportError 的消息到底是什么? iirc ImportErrors 在加载扩展模块时抛出问题,因此可能是由于忘记链接库 fex 引起的。
-
哇!当我尝试再次导入它时,它神奇地起作用了。我发誓我没有碰任何东西,或者做任何与我一直在做的不同的事情......尽管我想我一定做了不同的事情。 Cookie 给任何可能提供解释的人。 :)
-
不是""总是在路径前吗?
-
@mipadi:是的,'' 通常是第一个(并不总是,但通常是),这意味着在检查任何其他目录之前先检查本地目录以查找您的模块。开发人员经常在他们正在开发的同一个地方测试他们的导入,从而掩盖 PATH 问题。