时间:2021-05-22
前言
开发环境:
Centos 7 + Python 3.5.1 + Qt Creator(只是使用Qt Creator编译而已,并没有使用QT的任何库)
Python调用C/C++库,我现在能做到的有两种方式
1.extern “C” 导出(互相传值比较麻烦,不建议使用这种方式):
将C/C++库做成和平常一样的DLL和或者.so,比如:
//.h文件#include <Python.h>//.cpp文件//C/C++ my.so 或者my.dllenter "C" void printHello(){ std::cout<<"Hello World"<<std::endl;}#Pythonimport ctypes from ctypes import *loadso = ctypes.cdll.LoadLibrary mylib = loadso("./my.so")mylib.printHello()>>>Hello world代码解释:
my.so有一个C导出函数 printHello()
import ctypes : 导入官方的一个库,顾名思义和C有关
loadso = ctypes.cdll.LoadLibrary : loadso 表示加载库用的函数
mylib = loadso(“./my.so”) //或者loadso(“my.dll”) 加载my.so库
mylib.printHello() : 调用库函数
上述代码能正常输出:Hello World,但是他们没有互相传值
Python和C++互相传值
//.h文件#include <Python.h>//.cpp文件enter "C" int printHello(const char* str){ std::cout<<str<<std::endl; return 1; }那么Python的问题就来了
str = create_string_buffer(b"Hello World")#mylib.printHello("Hello World") 这里死活就是显示:H,*(str+4)才是'e',*(str+8) 是'l' 依次类推print (mylib.printHello(str))>>>Hello World>>>1#由于对Python不是特别的熟悉 怎么也做不到显示C++返回的字符串, Python只能显示C++返回的字符串子能看到一个地址而已2.Python扩展C/C++
不多说,直接上代码
//.h文件 本来这是C++连接Mysql 我只摘抄部分代#include <Python.h>//.cpp文件//传递多个参数 Python传过来的参数在args里面PyObject* printfHello(PyObject* self,PyObject* args){ int i=0 const char* str; if (!PyArg_ParseTuple(args, "i|s", &i,&str)) //i 表示整形 s 表示字符串 return PyLong_FromLong(0); print("%d,%s",i,str); return Py_BuildValue("s","OK"); //向Python返回OK字符串}//映射 知道MFC的一看就懂static PyMethodDef MyMethods[] = {{"printfHello", printfHello, METH_VARARGS, //"printHello" 中可调用的函数 METH_VARARGS :带有参数 METH_NOARGS:无参数"print"}, //说明{"connect", connect, METH_VARARGS,"connect mysql"},{NULL, NULL, 0, NULL}};static PyObject* UtilError;// 向Python中注册模块static struct PyModuleDef spammodule = { PyModuleDef_HEAD_INIT,"libMysqlUtil", //模块名字 import libMysqlUtil"C++ Connect Mysql",-1,MyMethods};//PyInit_libMysqlUtil 注意名字 一定要PyInit_ 加上你的模块名字 不然Python import 会提示没有定义 PyInit_你的模块名字 PyMODINIT_FUNC PyInit_libMysqlUtil(void) { PyObject* m = nullptr; m = PyModule_Create(&spammodule);//m= Py_InitModule(....) Python 2.7 if(!m) { return m; } UtilError = PyErr_NewException("Util.error",NULL,NULL); Py_INCREF(UtilError); PyModule_AddObject(m,"error",UtilError); return m; }#pythonimport libMysqlUtillibMysqlUtil.printHello(1,"hello World")>>>1,hello World>>>OK总结
到目前为止Python和C/C++互相通信,能适应大部分需求,结构体传值还没有研究,对于类,使用指针就行,C++里面是指针,在Python中会将指针转化成整形,Python将这个整形传给C++的时候使用PyArg_ParseTuple又将整形会变成类指针。
好了,以上就是本文的全部内容,希望本文的内容对大家学习python和C/C++能有所帮助。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
原理python没有办法直接和c++共享内存交互,需要间接调用c++打包好的库来实现流程C++共享内存打包成库python调用C++库往共享内存存图像数据C++
PyQtGraph是纯Python的,只是它底层调用的是PyQt,也就是Qt的Python封装,底层用C/C++语言开发的库,它是在PyQt的基础上开发的可视化
相比C++而言,Python适合做原型。本系列的文章介绍如何在Python中用OpenCV图形库,以及与C++调用相应OpenCV函数的不同之处。这篇文章介绍在
一、问题Python模块和C/C++的动态库间相互调用在实际的应用中会有所涉及,在此作一总结。二、Python调用C/C++1、Python调用C动态链接库Py
boost::asio编程-同步TCPboost.asio库是一个跨平台的网络及底层IO的C++编程库,它使用现代C++手法实现了统一的异步调用模型。boost