Air*_*d20 5 c++ python syntax pybind11
我有一个与此非常相似的结构:
struct data_point
{
data_point() = delete;
data_point(const int& data) :
m_data(data)
{}
int m_data;
};
Run Code Online (Sandbox Code Playgroud)
我也这样声明了这种类型。
typedef std::vector<data_point> data_list;
Run Code Online (Sandbox Code Playgroud)
该结构体的绑定定义如下:
PYBIND11_MODULE(data_lib, ref)
{
py::class_<data_point> dp(ref, "data_point");
dp.def(py::init<const int&>());
dp.def_readwrite("m_data", &data_point::m_data);
}
Run Code Online (Sandbox Code Playgroud)
如何定义 typedef 列表类型的绑定?我不清楚如何在 pybind 文档中执行此操作。
对于这个特定问题,当您包含 .pybind 时,pybind 会自动将 std::vector 类型解释为 python 列表"pybind11/stl.h"。因此,这种类型的绑定是不必要的。
前任:
#include "pybind11.h"
#include "pybind11/stl.h"
struct data_point
{
data_point() = delete;
data_point(const int& data) :
m_data(data)
{}
int m_data;
};
std::vector<data_point> make_vec(){
return {data_point(20), data_point(18)};
}
PYBIND11_MODULE(data_lib, ref)
{
py::class_<data_point> dp(ref, "data_point");
dp.def(py::init<const int&>());
dp.def_readwrite("m_data", &data_point::m_data);
ref.def("make_vec", &make_vec, "A function that returns a vector of data_points");
}
Run Code Online (Sandbox Code Playgroud)
在 python 中,当您导入data_lib库时,您将能够使用返回data_point.
import data_lib
p = data_lib.make_vec()
print len(p)
Run Code Online (Sandbox Code Playgroud)
输出:2