8

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

这些行运行正常,但对使我的代码正常工作没有影响。显然,我的真实代码有一大堆错误检查,我已经排除了,所以不用担心!

所以我的问题是:如何将嵌入式解释器适当地引导到我的脚本,以便我可以实例化这些类?

4

1 回答 1

18

你需要指定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;
}
于 2012-03-22T00:15:14.317 回答