2010-11-06 6 views
7

Я пытаюсь написать оболочку python для функции C. После написания всего кода и его компиляции Python не может импортировать модуль. Я следую приведенному примеру here. Я воспроизвожу его здесь, после исправления некоторых опечаток. Существует файл myModule.c:.so модуль не импортирует в python: динамический модуль не определяет функцию init

#include <Python.h> 

/* 
* Function to be called from Python 
*/ 
static PyObject* py_myFunction(PyObject* self, PyObject* args) 
{ 
    char *s = "Hello from C!"; 
    return Py_BuildValue("s", s); 
} 
/* 
* Bind Python function names to our C functions 
*/ 
static PyMethodDef myModule_methods[] = { 
    {"myFunction", py_myFunction, METH_VARARGS}, 
    {NULL, NULL} 
}; 

/* 
* Python calls this to let us initialize our module 
*/ 
void initmyModule() 
{ 
    (void) Py_InitModule("myModule", myModule_methods); 
} 

Так как я нахожусь на Mac с MacPorts питона, я скомпилировать как

$ g++ -dynamiclib -I/opt/local/Library/Frameworks/Python.framework/Headers -lpython2.6 -o myModule.dylib myModule.c 
$ mv myModule.dylib myModule.so 

Однако я получаю сообщение об ошибке при попытке импортировать его.

$ ipython 
In[1]: import myModule 
--------------------------------------------------------------------------- 
ImportError        Traceback (most recent call last) 

/Users/.../blahblah/.../<ipython console> in <module>() 

ImportError: dynamic module does not define init function (initmyModule) 

Почему я не могу импортировать его?

+0

Ваш код, кажется, немного искажен. –

+1

@ Игнасио: Я просто пытаюсь следовать примерам. Есть ли более простой пример, на который вы могли бы указать мне? – highBandWidth

+0

Действительно ли код в верхней части окна отражает то, что у вас есть в исходном файле? –

ответ

5

Поскольку вы используете компилятор C++, имена функций будут mangled (например, мой g++ искалечил void initmyModule() в _Z12initmyModulev). Поэтому интерпретатор python не найдет функцию init вашего модуля.

Вам нужно либо использовать простой компилятор C или C заставить связь в течение модуля с extern "C" директивы:

#ifdef __cplusplus 
extern "C" { 
#endif 

#include <Python.h> 

/* 
* Function to be called from Python 
*/ 
static PyObject* py_myFunction(PyObject* self, PyObject* args) 
{ 
    char *s = "Hello from C!"; 
    return Py_BuildValue("s", s); 
} 

/* 
* Bind Python function names to our C functions 
*/ 
static PyMethodDef myModule_methods[] = { 
    {"myFunction", py_myFunction, METH_VARARGS}, 
    {NULL, NULL} 
}; 

/* 
* Python calls this to let us initialize our module 
*/ 
void initmyModule() 
{ 
    (void) Py_InitModule("myModule", myModule_methods); 
} 

#ifdef __cplusplus 
} // extern "C" 
#endif 
+2

Макрос 'PyMODINIT_FUNC', указанный в документации, будет обрабатывать это для вас. –

+0

@ IgnacioVazquez-Abrams: Не могли бы вы рассказать о том, как выполнить свое решение? Благодарю. – RDK

 Смежные вопросы

  • Нет связанных вопросов^_^