使用C ++,PyObject中的参数创建Python构造函数

时间:2016-10-19 22:13:38

标签: python c++ tuples python-embedding pyobject

我有一个像这样的python类A

class A: 
   def __init__(self, name): 
       self.name = name

   def print_lastname(self, lastname): 
       print(lastname)

我必须像这样调用这段代码。

import B
a = B.A("hello")
a.print_lastname("John")

目前,我需要在我的C ++代码中使用这个A类。我已经走到了这一步。

Py_Initialize(); 
string hello = "hello"; 
PyObject *module, *attr, *arg; 
module = PyObject_ImportModule("B"); // import B
attr = PyObject_GetAttrString(module, "A"); // get A from B
arg = PyString_FromString(hello.c_str()); 
instance = PyInstance_New(attr, arg, NULL); // trying to get instance of A with parameter "hello"
Py_Finalize(); 

但我收到错误

  

Exception TypeError:'参数列表必须是元组'在模块'线程'来自' /usr/lib64/python2.7/threading.pyc'

如何从C ++实现import语句到a.print_name("John")? 任何帮助表示赞赏。

1 个答案:

答案 0 :(得分:5)

我将略微重写Python类,只是因为它使用了参数和成员变量。

# B.py - test module
class A:
    def __init__(self, name):
        self.name = name

    def print_message(self, message):
        print message + ' ' + self.name

对于C ++部分,几乎一切看起来都不错。您获得的错误是因为PyInstance_New的参数应该是一个元组。调用函数或方法有多种方法。以下是使用其中一个的完整示例:

// test.c - test embedding.
void error_abort(void)
{
    PyErr_Print();
    exit(EXIT_FAILURE);
}

int main(int argc, char* argv[])
{
    PyObject* temp, * args, * attr, * instance;

    Py_Initialize();
    if (!(temp = PyString_FromString("John")))
        error_abort();
    if (!(args = PyTuple_Pack(1, temp)))
        error_abort();
    Py_DECREF(temp);

    if (!(temp = PyImport_ImportModule("B")))
        error_abort();
    if (!(attr = PyObject_GetAttrString(temp, "A")))
        error_abort();
    Py_DECREF(temp);

    if (!(instance = PyInstance_New(attr, args, NULL)))
        error_abort();
    if (!PyObject_CallMethod(instance, "print_message", "s", "Hello"))
        error_abort();

    Py_DECREF(args);
    Py_DECREF(attr);
    Py_DECREF(instance);
    Py_Finalize();
    return 0;
}

有关详细信息,请参阅Python pure-embedding