用C ++创建python对象并调用它的方法

时间:2016-10-02 02:29:32

标签: python c++

在下面关于python嵌入的文档中,很好地描述了如何在“C”代码中嵌入python方法。 https://docs.python.org/2/extending/embedding.html

我测试了上面的代码,它也适用于g ++编译器。

但是上面显示了调用全局方法而不是类方法的示例。

有没有人可以展示如何创建Python对象并从C ++调用其方法的示例?

1 个答案:

答案 0 :(得分:3)

通过一些调查,我发现可以使用以下四个API串联完成。

  • PyModule_GetDict;获取属于python模块的项目。 *

  • PyDict_GetItemString;获取与Python类对应的项 名称。

  • PyObject_CallObject;创建Python对象。 *
  • PyObject_CallMethod;对对象的方法进行分类。

以下是我创建的示例代码,即使它仍然需要改进。

// Refer to the following website for more information about embedding the
// Python code in C++.
// https://docs.python.org/2/extending/embedding.html
int main() {
  PyObject *module_name, *module, *dict, *python_class, *object;

  // Initializes the Python interpreter
  Py_Initialize();

  module_name = PyString_FromString(
      "work.embedding_python_in_cpp.example.adder");

  // Load the module object
  module = PyImport_Import(module_name);
  if (module == nullptr) {
    PyErr_Print();
    std::cerr << "Fails to import the module.\n";
    return 1;
  }
  Py_DECREF(module_name);

  // dict is a borrowed reference.
  dict = PyModule_GetDict(module);
  if (dict == nullptr) {
    PyErr_Print();
    std::cerr << "Fails to get the dictionary.\n";
    return 1;
  }
  Py_DECREF(module);

  // Builds the name of a callable class
  python_class = PyDict_GetItemString(dict, "Adder");
  if (python_class == nullptr) {
    PyErr_Print();
    std::cerr << "Fails to get the Python class.\n";
    return 1;
  }
  Py_DECREF(dict);

  // Creates an instance of the class
  if (PyCallable_Check(python_class)) {
    object = PyObject_CallObject(python_class, nullptr);
    Py_DECREF(python_class);
  } else {
    std::cout << "Cannot instantiate the Python class" << std::endl;
    Py_DECREF(python_class);
    return 1;
  }

  int sum = 0;
  int x;

  for (size_t i = 0; i < 5; i++) {
    x = rand() % 100;
    sum += x;
    PyObject *value = PyObject_CallMethod(object, "add", "(i)", x); 
    if (value)
      Py_DECREF(value);
    else
      PyErr_Print();
  }
  PyObject_CallMethod(object, "printSum", nullptr);
  std::cout << "the sum via C++ is " << sum << std::endl;

  std::getchar();
  Py_Finalize();

  return (0);
}