在 pip 包构建上编译 Cython

Compile Cython on pip package build

我正在开发一个 Python 包,EcoPy,它主要是用纯 Python 编写的。主文件夹称为 ecopy。有一个名为 regression 的子文件夹,其中包含一个已经构建的 Cython 文件。主 setup.py 文件包含代码:

ext_modules = cythonize([
    Extension(
        'ecopy.regression.isoFunc', ['ecopy/regression/isoFunc.pyx'], **opts),
])

当我运行

sudo pip install ecopy -e . --upgrade --force-reinstall

模块构建良好。如果我删除了 isoFunc.c 文件,它甚至会重新编译它。问题是 Cython 然后没有将 .c 文件转换为 .so 文件,我需要它来导入函数。如果我尝试在没有它的情况下加载模块,我会得到

ImportError: No module named isoFunc

如果我使用命令行手动设置文件

python setup.py build_ext --inplace

Cython 会生成 .so 文件。如何使用 pip 生成 .so 文件?我试图通过阅读他们的代码来弄清楚 statsmodels 是如何做到的,但老实说,这对我来说是个谜。

就好像 pip 命令遗漏了 build_ext 参数。

我可以回答这个问题,因为我才知道我是个白痴。

sudo pip install ecopy -e . --upgrade --force-reinstall

正在使用 PyPI 的旧版本,该版本没有新的 setup.py 和 Cython 代码。当我做对时

sudo pip install -e . --upgrade --force-reinstall

并在我的硬盘上使用了最新版本,它运行良好。

小小的胜利。

我来这里是因为我不确定 pip 安装我的包是否足以自动编译 Cython 源代码。看起来确实如此,但默认情况下 pip 输出似乎没有记录。我注意到 pip install -e . -v 非常清楚编译和 link 步骤是否/具体做了什么:

Running setup.py develop for mypackage
  [...]
  running build_ext
  cythoning mypackage/my_cython_module.pyx to mypackage/my_cython_module.c
  building 'mypackage.my_cython_module' extension
  x86_64-linux-gnu-gcc [...] -c mypackage/my_cython_module.c -o build/temp.linux-x86_64-2.7/mypackage/my_cython_module.o
  x86_64-linux-gnu-gcc [...] build/temp.linux-x86_64-2.7/mypackage/my_cython_module.o -o build/lib.linux-x86_64-2.7/mypackage/my_cython_module.so
  copying build/lib.linux-x86_64-2.7/mypackage/my_cython_module.so -> mypackage
  [...]