我想创建一个嵌入式python3解释器,让python脚本导入通过cythonapi创建的模块。在
创建一个“顶级”模块没问题,但现在我想把我的模块组织成包。。。但我失败了。在
以下是我当前的(简单)代码:
#include <Python.h>
//// Definition of 'emb.sub' module
static PyObject* emb_sub_foo(PyObject *self, PyObject *args)
{
char const* n = "I am sub foo";
return Py_BuildValue("s", n);
}
static PyMethodDef EmbSubMethods[] = {
{"foo", emb_sub_foo, METH_VARARGS, "Returns sub foo"},
{NULL, NULL, 0, NULL}
};
static PyModuleDef EmbSubModule = {
PyModuleDef_HEAD_INIT, "emb.sub", NULL, -1, EmbSubMethods,
NULL, NULL, NULL, NULL
};
static PyObject* PyInit_emb_sub(void)
{
return PyModule_Create(&EmbSubModule);
}
//// Embedded Python
int main()
{
PyImport_appendInittab("emb.emb", &PyInit_emb_sub);
Py_Initialize();
PyRun_SimpleString("import emb.sub\n");
Py_Finalize();
return 0;
}
当我执行程序时,我得到:
^{pr2}$因此,我创建了一个空的emb模块,并将其__path__
设置为:
#include <Python.h>
//// Definition of 'emb' module
static PyModuleDef EmbModule = {
PyModuleDef_HEAD_INIT, "emb", NULL, -1, NULL,
NULL, NULL, NULL, NULL
};
static PyObject* PyInit_emb(void)
{
PyObject *mod = PyModule_Create(&EmbModule);
PyModule_AddObject(mod, "__path__", Py_BuildValue("()"));
return mod;
}
//// Definition of 'emb.sub' module
static PyObject* emb_sub_foo(PyObject *self, PyObject *args)
{
char const* n = "I am sub foo";
return Py_BuildValue("s", n);
}
static PyMethodDef EmbSubMethods[] = {
{"foo", emb_sub_foo, METH_VARARGS, "Returns sub foo"},
{NULL, NULL, 0, NULL}
};
static PyModuleDef EmbSubModule = {
PyModuleDef_HEAD_INIT, "emb.sub", NULL, -1, EmbSubMethods,
NULL, NULL, NULL, NULL
};
static PyObject* PyInit_emb_sub(void)
{
return PyModule_Create(&EmbSubModule);
}
//// Embedded Python
int main()
{
PyImport_AppendInittab("emb", &PyInit_emb);
PyImport_AppendInittab("emb.sub", &PyInit_emb_sub);
Py_Initialize();
PyRun_SimpleString("import emb.sub\n");
Py_Finalize();
return 0;
}
现在我得到一个错误:
Traceback (most recent call last):
File "<string>", line 1, in <module>
ImportError: No module named 'emb.sub'
我想知道是否可以在嵌入式python中创建包和模块的层次结构?在
谢谢!在
根据默认的模块名称,处理模块+时,模块名称无法匹配。可以通过添加自定义导入钩子来解决这一问题,只需在Py_Initialize()之后运行它:
我成功地用你的完整代码尝试了:
^{pr2}$相关问题 更多 >
编程相关推荐