3

我目前有以下内容:

namespace py=boost::python;

//C++
void f() {
    std::cout << "hello world\n";
}

//I am not precious about this, if it can be done without a module that would be great
BOOST_PYTHON_MODULE(test)
{
    py::def("f", f);
}

int main() {
    auto main_module    =py::import("__main__");
    auto main_namespace =main_module.attr("__dict__");
    //???????
    auto result=py::exec_file("t.py", main_namespace);
}

//t.py
f()

我试图打电话给 f,但我不确定让它工作所需的胶水。我可以上课

 int main() {
     //...

     py::obejct p_my_type=py::class_<my_type>("my_type").def("f", &my_type::f);
     main_namespace["my_type"]=p_my_type;

     //...

但是boost::python::def似乎没有返回喜欢boost::python::object的东西class_

我的问题是,如何让第一个测试用例按预期工作?其次,我在第二个代码片段“正确”中公开我的类型的方式是什么?

4

1 回答 1

0

修复很简单,但在此页面的文档中没有提到:

http://www.boost.org/doc/libs/1_55_0/libs/python/doc/tutorial/doc/html/python/embedding.html

我需要这样做:

auto main_module    =py::import("__main__");
auto main_namespace =main_module.attr("__dict__");
inittest();
auto result=py::exec_file("t.py", main_namespace);


from test import f
f()
于 2013-11-14T23:10:36.027 回答