boost::python: Python リストから std::vector へ 質問する

boost::python: Python リストから std::vector へ 質問する

ついに、[] 演算子を使って python で std::vector を使用できるようになりました。コツは、内部のベクトルを処理するコンテナーを boost C++ ラッパーに提供するだけです。

#include <boost/python.hpp>
#include <vector>
class world
{
    std::vector<double> myvec;

    void add(double n)
    {
        this->myvec.push_back(n);
    }

    std::vector<double> show()
    {
     return this->myvec;
    }
};

BOOST_PYTHON_MODULE(hello)
{
    class_<std::vector<double> >("double_vector")
        .def(vector_indexing_suite<std::vector<double> >())
    ;

    class_<World>("World")
     .def("show", &World::show)
        .def("add", &World::add)
    ;
 }

もう一つの課題は、Python リストを std::vector に変換する方法です。パラメータとして std::vector を期待する C++ クラスを追加し、対応するラッパー コードを追加しました。

#include <boost/python.hpp>
#include <vector>
class world
{
    std::vector<double> myvec;

    void add(double n)
    {
        this->myvec.push_back(n);
    }

    void massadd(std::vector<double> ns)
    {
        // Append ns to this->myvec
    }

    std::vector<double> show()
    {
     return this->myvec;
    }
};

BOOST_PYTHON_MODULE(hello)
{
    class_<std::vector<double> >("double_vector")
        .def(vector_indexing_suite<std::vector<double> >())
    ;

    class_<World>("World")
     .def("show", &World::show)
        .def("add", &World::add)
        .def("massadd", &World::massadd)
    ;
 }

しかし、そうすると、次の Boost.Python.ArgumentError が発生します。

>>> w.massadd([2.0,3.0])
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
Boost.Python.ArgumentError: Python argument types in
    World.massadd(World, list)
did not match C++ signature:
    massadd(World {lvalue}, std::vector<double, std::allocator<double> >)

C++ 関数内で Python リストにアクセスする方法を教えてもらえますか?

ありがとう、ダニエル

ベストアンサー1

C++メソッドでPythonリストを受け入れるには、boost::python::list

void massadd(boost::python::list& ns)
{
    for (int i = 0; i < len(ns); ++i)
    {
        add(boost::python::extract<double>(ns[i]));
    }
}

おすすめ記事