前言
開發(fā)環(huán)境:
Centos 7 + Python 3.5.1 + Qt Creator(只是使用Qt Creator編譯而已,并沒有使用QT的任何庫)
Python調用C/C++庫,我現(xiàn)在能做到的有兩種方式
1.extern “C” 導出
(互相傳值比較麻煩,不建議使用這種方式):
將C/C++庫做成和平常一樣的DLL和或者.so,比如:
//.h文件
#include
//.cpp文件
//C/C++ my.so 或者my.dll
enter "C" void printHello()
{
std::cout<<"Hello World"<
#Python
import ctypes
from ctypes import *
loadso = ctypes.cdll.LoadLibrary
mylib = loadso("./my.so")
mylib.printHello()
>>>Hello world
代碼解釋:
my.so
有一個C導出函數(shù)
printHello()
import ctypes? : 導入官方的一個庫,顧名思義和C有關
loadso = ctypes.cdll.LoadLibrary? : loadso 表示加載庫用的函數(shù)
mylib = loadso(“./my.so”) //或者loadso(“my.dll”)? 加載my.so庫
mylib.printHello() : 調用庫函數(shù)
上述代碼能正常輸出:Hello World,但是他們沒有互相傳值
Python和C++互相傳值
//.h文件
#include
//.cpp文件
enter "C" int printHello(const char* str)
{
std::cout<
<
那么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
//.cpp文件
//傳遞多個參數(shù) Python傳過來的參數(shù)在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" 中可調用的函數(shù) METH_VARARGS :帶有參數(shù) METH_NOARGS:無參數(shù)
"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; }
#python
import libMysqlUtil
libMysqlUtil.printHello(1,"hello World")
>>>1,hello World
>>>OK
總結
到目前為止Python和C/C++互相通信,能適應大部分需求,結構體傳值還沒有研究,對于類,使用指針就行,C++里面是指針,在Python中會將指針轉化成整形,Python將這個整形傳給C++的時候使用PyArg_ParseTuple又將整形會變成類指針。
好了,以上就是本文的全部內容,希望本文的內容對大家學習python和C/C++能有所幫助。
更多文章、技術交流、商務合作、聯(lián)系博主
微信掃碼或搜索:z360901061
微信掃一掃加我為好友
QQ號聯(lián)系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元

