1

我正在使用 boost python 在我的 C++ 应用程序中嵌入 python。

我希望能够调用 boost python 函数对象,并将全局名称空间与该函数调用相关联。具体来说,简化后的相关代码为:

bp::object main = bp::import("__main__");
bp::object main_namespace = main.attr("__dict__");


//Put the function name runPyProg in the main_namespace

bp::object PyProg = exec(
        "import cStringIO\n"
        "import sys\n"
        "sys.stderr = cStringIO.StringIO()\n"
        "def runPyProg(exp):\n"
        "    print exp\n"
        "    exec(exp)\n"
        "    return\n"
        "\n",main_namespace);

//Now call the python function runPyProg with an argument

bp::object py_fn = main.attr("runPyProg");
py_fn(expStr)

我知道当我使用 boost python exec() 函数时,我可以在全局命名空间中发送,如上所示。我的问题是当我调用 py_fn 时如何将 main_namespace 与 python 函数相关联?我的最终目标是将来自 runPyProg 的局部变量放在 main_namespace 中。

谢谢你。

4

1 回答 1

4

如果我正确理解了这个问题,那么它应该像指定exec将执行的上下文一样简单。函数或方法可以访问通过globals(). globals()因此,从内部调用runPyProg()将返回 Python 等价的main_namespace. 此外,exec接受两个可选参数:

  • 第一个参数指定将用于的字典globals()。如果省略第二个参数,那么它也用于locals().
  • 第二个参数指定将用于的字典locals()。内部发生的变量变化exec应用于locals().

因此,改变:

exec exp

exec exp in globals()

并且它应该提供所需的行为,其中exp可以与main_namespace.


这是一个基本示例:

#include <boost/python.hpp>

int main()
{
  Py_Initialize();

  namespace python = boost::python;
  python::object main = python::import("__main__");
  python::object main_namespace = main.attr("__dict__");

  //Put the function name runPyProg in the main_namespace
  python::exec(
    "def runPyProg(exp):\n"
    "    print exp\n"
    "    exec exp in globals()\n"
    "    return\n"
    "\n", main_namespace);

  // Now call the python function runPyProg with an argument
  python::object runPyProg = main.attr("runPyProg");

  // Set x in python and access from C++.
  runPyProg("x = 42");
  std::cout << python::extract<int>(main.attr("x")) << std::endl;

  // Set y from C++ and access within python.
  main.attr("y") = 100;
  runPyProg("print y");

  // Access and modify x in python, then access from C++.
  runPyProg("x += y");
  std::cout << python::extract<int>(main.attr("x")) << std::endl;
}

评论输出:

x = 42          // set from python
42              // print from C++
                // y set to 100 from C++
print y         // print y from python
100             //
x += y          // access and modify from python
142             // print x from C++
于 2013-05-13T14:54:34.510 回答