用CyGub IMP编译C++嵌入的Python

2024-09-30 20:26:02 发布

您现在位置:Python中文网/ 问答频道 /正文

我试图在使用CMAGE编译的C++项目中包含Python文件。在

首先,我使用以下两个文件独立完成此操作:

#include <Python.h>
#include <stdio.h>

int main(int argc, char *argv[])
{
  setenv("PYTHONPATH", ".", 0);
  char hostname[] = "localhost";
  PyObject *pName, *pModule, *pFunc;
  PyObject *pArgs, *pValue;
  Py_Initialize();
  pName = PyString_FromString("GetHostname");
  pModule = PyImport_Import(pName);
  Py_DECREF(pName);

  if(pModule != NULL) {
    pFunc = PyObject_GetAttrString(pModule, "GetHostname");

    if (pFunc && PyCallable_Check(pFunc)) {
      pArgs = PyTuple_New(1);
      pValue = PyString_FromString(hostname);
      PyTuple_SetItem(pArgs, 0, pValue);
      pValue = PyObject_CallObject(pFunc, pArgs);
      Py_DECREF(pArgs);
      if (pValue != NULL) {
    printf("The IP address is %s\n", PyString_AsString(pValue));
    Py_DECREF(pValue);
      }
      else {
    Py_DECREF(pFunc);
    Py_DECREF(pModule);
    PyErr_Print();
    fprintf(stderr, "Call Failed\n");
    return 1;
      }
    }
    else {
      if (PyErr_Occurred())
    PyErr_Print();
      fprintf(stderr, "Cannot find function\n");
    }
    Py_XDECREF(pFunc);
    Py_DECREF(pModule);
  }
  else {
    PyErr_Print();
    fprintf(stderr, "Failed to load file\n");
    return 1;
  }
  Py_Finalize();
  return 0;
}

以及

^{pr2}$

当我使用

g++ $(python-config --cflags) -o test $(python-config --ldflags) ./test.cpp

how to link python static library with my c++ program开始一切正常。在

但这是包含在一个使用CMake编译的项目中的,我一定是做错了什么,因为编译之后我得到了

Traceback (most recent call last):
  File "/src/GetHostname.py", line 1, in <module>
    import socket
  File "/usr/lib64/python2.6/socket.py", line 46, in <module>
    import _socket
ImportError: /usr/lib64/python2.6/lib-dynload/_socketmodule.so: undefined symbol: PyExc_ValueError

在CMakeLists.txt文件我加了行

find_package( PythonInterp REQUIRED )
find_package( PythonLibs REQUIRED )
include_directories ( ${PYTHON_INCLUDE_DIRS} )
add_library (GetHostname MODULE GetHostname.cc)
target_link_libraries(GetHostname ${PYTHON_LIBRARIES})
CONFIGURE_FILE(${PATH_TO_SOURCE}GetHostname.py ${PATH_TO_BUILD}GetHostname.py COPYONLY)

基于此线程Python.h: No such file or directory

所有的东西都会编译,但是python模块由于错误而无法加载。我在CMake中没有正确链接python库吗?在

任何能够解释其失败原因的想法都是受欢迎的。在

使用Python2.6

<>我知道这可以在C++中完成,但是这不是我需要包括的唯一的Python模块,所以在C++中重写它并不是我要找的答案。我也知道目前本地主机的IP地址是已知的,这只是为了测试目的。在


Tags: 文件pyifincludepyobjectpvaluepnamepystring
1条回答
网友
1楼 · 发布于 2024-09-30 20:26:02

所以我终于自己找到了答案。在

问题是,当在CMake链接时,与Python库的链接只加载在本地(RTLD-Posil),这意味着实际的Python脚本与Python库没有关联,只有C++。在

修复此选项,只需加载具有全局符号分辨率的Python库,这是C++代码中的第一件事。在

dlopen("libpython2.6.so.1.0", RTLD_NOW | RTLD_NOLOAD | RTLD_GLOBAL);

这是一个快速而肮脏的修复方法,因为它是python2.6特有的,您应该通过根据计算机上安装的版本在CMake中定义变量来实现这一点。在

您必须导入dlfcn才能使用dlopen:

^{pr2}$

相关问题 更多 >