我将Python嵌入到具有已定义API的C/C++应用程序中。
应用程序需要实例化脚本中定义的类,这些类的结构大致如下:
class userscript1:
def __init__(self):
##do something here...
def method1(self):
## method that can be called by the C/C++ app...etc
过去(为了概念验证)我已经设法使用以下类型的代码来完成此任务:
PyObject* pName = PyString_FromString("userscript.py");
PyObject* pModule = PyImport_Import(pName);
PyObject* pDict = PyModule_GetDict(pModule);
PyObject* pClass = PyDict_GetItemString(pDict, "userscript");
PyObject* scriptHandle = PyObject_CallObject(pClass, NULL);
现在我更多地处于生产环境中,这在PyImport_Import行上失败了-我认为这可能是因为我试图在目录前添加脚本名称,例如
PyObject* pName = PyString_FromString("E:\\scriptlocation\\userscript.py");
现在,为了让您了解我尝试过的方法,我尝试在所有这些调用之前修改系统路径,以使其搜索此模块。基本上尝试以编程方式修改sys.path:
PyObject* sysPath = PySys_GetObject("path");
PyObject* path = PyString_FromString(scriptDirectoryName);
int result = PyList_Insert(sysPath, 0, path);
这些行运行正常,但对使我的代码正常工作没有任何作用。显然,我的真实代码中有大量错误检查已排除在外,因此不必担心!
所以我的问题是:如何将嵌入式解释器适当地定向到脚本,以便实例化类?
最佳答案
您需要指定userscript
而不是userscript.py
也要使用PyImport_ImportModule
,它直接需要char *
userscript.py
表示py
包中的模块userscript
该代码对我有用:
#include <stdio.h>
#include <stdlib.h>
#include <Python.h>
int main(void)
{
const char *scriptDirectoryName = "/tmp";
Py_Initialize();
PyObject *sysPath = PySys_GetObject("path");
PyObject *path = PyString_FromString(scriptDirectoryName);
int result = PyList_Insert(sysPath, 0, path);
PyObject *pModule = PyImport_ImportModule("userscript");
if (PyErr_Occurred())
PyErr_Print();
printf("%p\n", pModule);
Py_Finalize();
return 0;
}