使用pybind11绑定typedef类型的正确语法是什么?

时间:2018-06-06 21:39:09

标签: python c++ syntax pybind11

我有一个非常类似的结构:

struct data_point
{
    data_point() = delete;
    data_point(const int& data) :
            m_data(data)
    {}

    int m_data;
};

我也声明了这种类型。

typedef std::vector<data_point> data_list;

定义了此结构的绑定:

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);
}

如何为typedef列表类型定义绑定? 我不清楚如何在pybind文档中这样做。

1 个答案:

答案 0 :(得分:0)

对于此特定问题,当您包含"pybind11/stl.h"时,pybind会自动将std :: vector类型解释为python列表。因此,不需要这种类型的绑定。

例如:

#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");
}

在python中,当您导入data_lib库时,您将能够使用返回data_point列表的函数。

import data_lib
p = data_lib.make_vec()
print len(p)

输出:2