我写了一些生成std :: vector的C++代码。暴露std :: vector <double>与boost.python
我也有一个Python脚本来操纵一些数据,现在我声明像这样(下面)。
import numpy
x = numpy.random.randn(1000)
y = numpy.random.randn(1000)
我可以正常运行脚本。从我的C++代码:
using namespace boost::python;
try{
Py_Initialize();
object main = import("__main__");
object global(main.attr("__dict__"));
object result = exec_file("scatterPlot.py", global, global);
Py_Finalize();
}
catch(error_already_set){
PyErr_Print();
}
return;
我不知道如何让我的C++数据到python。我有很多,但似乎没有什么明确的。
我有我的C++
BOOST_PYTHON_MODULE(vector_indexing_suite_ext){
boost::python::class_<std::vector<double> >("PyVec")
.def(boost::python::vector_indexing_suite<std::vector<double> >());
}
这似乎是工作,但据我所知,它只是提供了一个类“PyVec”我的Python脚本,但我并不需要的数据。我错了吗?
我也看到一些其他人使用boost::shared_ptr in a python mailing list。
我还发现this example,但发现它令人困惑。
我能想到的几种方法
- 传递一些东西到
boost::python::exec_file
方法 - 使用
boost_indexing_suite_ext
- Uinsg
boost::shared_ptr
哪种方法是最容易得到持续?没有办法似乎对我很清楚。
这里有一些更多的链接,我看了看: from the boost website from the python website another mailing list thread
UPDATE:
这适用于传递一个int
我的Python代码像下面
int main(){
int five_squared=0;
int a =3;
try {
Py_Initialize();
object main_module = import("__main__");
object main_namespace = main_module.attr("__dict__");
main_namespace["var"]=a;
object ignored = exec("result = 5 ** var", main_namespace);
five_squared = extract<int>(main_namespace["result"]);
} catch(error_already_set) {
PyErr_Print();
}
std::cout << five_squared << std::endl;
return 0;
}
但我想通过一个载体,当我尝试以类似的方式做到这一点,我得到了■错误
TypeError: No to_python (by-value) converter found for C++ type: std::vector >
所以,很显然,我需要告诉蟒蛇如何处理的std ::向量。我认为这个代码可以帮助解决这个问题。
BOOST_PYTHON_MODULE(vector_indexing_suite_ext){
boost::python::class_<std::vector<double> >("PyVec")
.def(boost::python::vector_indexing_suite<std::vector<double> >());
}
但由于标准::向量是很常见的,必须有一个定义的方式来做到这一点,对吧?
真棒,这真的有帮助 – devin 2010-01-12 06:05:45
有没有更多的面向对象的方式做到这一点?而不是传递一个python字符串来执行..一个la将矢量转换为sum可以处理并创建一个对象的类型sum = main_module(“sum”); ...? – SullX 2014-01-24 04:33:16