使用 cython 将 c++ 中的 helloworld 包装到 python 时出错

Error when wrapping helloworld in c++ into python with cython

我有以下文件:

helloworld.cpp 其中包含

#include <iostream>                                                     
#include <Python.h>                                                     

void Helloworld(){                                                      
  std::cout << "Hello world!" << "\n";                                  
}

helloworld.pyx 其中包含:

cdef extern from "helloworld.cpp":                                      
    cpdef void Helloworld() 

setup.py 其中包含:

from distutils.core import setup                                        
from distutils.extension import Extension                               
from Cython.Build import cythonize                                      

ext = Extension('helloworld', sources=["helloworld.pyx"], language="c++")                                                                      

setup(name="helloworld", ext_modules = cythonize([ext]))

当我 运行 在 Ipython 中执行以下命令时,它会正确构建

In [1]: run setup.py build_ext --inplace --verbose
running build_ext
building 'helloworld' extension
gcc -pthread -Wsign-compare -DNDEBUG -g -fwrapv -O3 -Wall -Wstrict-prototypes -fPIC -I/home/ash/anaconda2/envs/python3/include/python3.5m -c helloworld.cpp -o build/temp.linux-x86_64-3.5/helloworld.o
cc1plus: warning: command line option ‘-Wstrict-prototypes’ is valid for C/ObjC but not for C++
g++ -pthread -shared -L/home/ash/anaconda2/envs/python3/lib -Wl,-rpath=/home/ash/anaconda2/envs/python3/lib,--no-as-needed build/temp.linux-x86_64-3.5/helloworld.o -L/home/ash/anaconda2/envs/python3/lib -lpython3.5m -o /home/ash/CallingC++fromPython/Cython/HelloWorld/helloworld.cpython-35m-x86_64-linux-gnu.so

但是当我尝试导入它时出现以下错误:

In [2]: import helloworld
------------------------------------------------------------------------
ImportError                            Traceback (most recent call last)
<ipython-input-12-9f213747d34d> in <module>()
----> 1 import helloworld

ImportError: dynamic module does not define module export function (PyInit_helloworld)

我也试过以下方法:

helloworld.pyx 包含:

cdef extern from "helloworld.cpp":                                      
    void Helloworld()

def C_Helloworld():
    return Helloworld()

在这种情况下,当我尝试构建它时,我得到:

run setup.py build_ext --inplace --verbose
running build_ext
building 'helloworld' extension
gcc -pthread -Wsign-compare -DNDEBUG -g -fwrapv -O3 -Wall -Wstrict-prototypes -fPIC -I/home/ash/anaconda2/envs/python3/include/python3.5m -c helloworld.cpp -o build/temp.linux-x86_64-3.5/helloworld.o
cc1plus: warning: command line option ‘-Wstrict-prototypes’ is valid for C/ObjC but not for C++
In file included from helloworld.cpp:458:0,
                 from helloworld.cpp:458,
                 from helloworld.cpp:458,
                 from helloworld.cpp:458,
...
                 from helloworld.cpp:458,
                 from helloworld.cpp:458,
                 from helloworld.cpp:458:
helloworld.cpp:16:20: error: #include nested too deeply
helloworld.cpp:23:20: error: #include nested too deeply
helloworld.cpp:163:27: error: #include nested too deeply
In file included from helloworld.cpp:458:0,
                 from helloworld.cpp:458,
                 from helloworld.cpp:458,
...

这意味着它被递归调用。

我认为是因为你的模块是空的,没有定义任何函数。

Cython 不创建包装器。你必须告诉他如何使用你的c++函数。

此外,“.pyx”文件的内容通常位于“.pxd”文件中。 “.pyx”文件包含将从 python 调用的函数。示例:

def hello_world():
    Helloworld()

问题是 two-fold。一是,正如 manawy 所说,我没有包装器 python 函数来调用 C++ 函数。另一个问题是我的 C++ 文件与 .pyx 文件同名,因此在编译它时,它递归地覆盖了 C++ 文件。