使用 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++ 文件。
我有以下文件:
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++ 文件。