我发现这个非常有用的问题和答案: Return vector<pair<int,int>> & from c++ method to python list of tuples using swig typemap
但是如果它不是引用,我在迭代返回向量时会遇到一些问题,例如:
myclass.h:
#include <vector>
#include <utility>
using std::vector;
using std::pair;
class MyClass {
private:
vector<pair<int,int> > _myvector;
public:
MyClass( );
const vector<pair<int,int> > & GetMyVector() const;
};
myclass.cpp:
#include "myclass.h"
MyClass::MyClass(): _myvector()
{_myvector.push_back(std::make_pair(1,2));_myvector.push_back(std::make_pair(1,2));};
const vector<pair<int,int>> & MyClass::GetMyVector() const {
return _myvector;
};
myclass.i:
%module x
%include <std_pair.i>
%include <std_vector.i>
%include <std_string.i>
%template() std::pair<int,int>;
%template(PairVector) std::vector<std::pair<int,int> >;
%{
#include "myclass.h"
%}
%include "myclass.h"
编译:
g++ -std=c++11 -c -fPIC myclass.cpp
swig -c++ -v -python myclass.i
g++ -std=c++11 -fPIC -c myclass.cpp myclass_wrap.cxx -I/usr/include/python2.7
g++ myclass.o myclass_wrap.o -shared -fPIC -o _x.so
但是当我在python中运行这样的东西时:
import x
b=x.MyClass()
print(b.GetMyVector())
for a,b in b.GetMyVector():
print(a,b)
然后我得到:
<Swig Object of type 'vector< std::pair< int,int >,std::allocator< std::pair< int,int > > > *' at 0x7ff06804b1b0>
Traceback (most recent call last):
File "Test.py", line 6, in <module>
for a,b in b.GetMyVector():
TypeError: 'SwigPyObject' object is not iterable
如何在python中正确迭代返回的向量?为什么返回一个指向vector的指针?我是否必须更改swig文件中的内容?
如果相关:(在Ubuntu上)
答案 0 :(得分:0)
SWIG无法正确理解using
指令。
与此问答相同: SWIG argument error when using "using std::vector" in python
至于为什么返回一个指针,好吧,如果SWIG无法将返回的对象转换为python对象,那么它会包装一个指向该对象的指针。