我将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;
}

08-16 21:18