python使用ctypes調用C/C++
1. ctpes介紹
ctypes is a foreign function library for Python. It provides C compatible data types, and allows calling functions in DLLs or shared libraries. It can be used to wrap these libraries in pure Python.
官方文檔地址: https://docs.python.org/3/library/ctypes.html
2.使用ctypes調用C語言
python對于標準C的兼容做的相當不錯,調用起來相對比較簡單,下面給大家上案例
1. 創建一個adder.c文件,代碼如下:
#include <stdio.h> int add_int(int, int); float add_float(float, float); int add_int(int num1, int num2) { return num1 + num2; } float add_float(float num1, float num2) { return num1 + num2; }這是一個標準C編寫的連個函數,用來計算兩個整數相加和兩個單精度浮點數相加
2. 編譯生成.so文件供python程序調用
在linux環境下使用gcc對adder.c進行編譯
命令: gcc adder.c -fPIC -shared -o adder.so
3.在python程序中調用.so
創建一個python文件,命令為adder.py,代碼如下:
from ctypes import *adder = CDLL("./adder.so")res_int = adder.add_int(4,5)print("result: " + str(res_int))然后在終端里執行命令: python adder.py
執行命令之后就能獲得到輸出了。
3. 使用ctypes調用C++
與調用C語言不通,在調用C++代碼時,需要在源文件中增加一個extern "C"的代碼塊
1.創建一個adder_plus.cpp文件,代碼如下:
#include <stdio.h>#include <iostream>using namespace std;int add_integer(int a , int b);float add_float(float a, float b);int add_integer(int a , int b){ return a + b;}float add_float(float a, float b){ return a + b;}extern "C"{ int add_integer_plus(int a , int b){ return add_integer(a, b); } float add_float_plus(float a, float b){ return add_float(a ,b); }}在extern "C"里的代碼是暴露給的python的接口,可以使用CDLL進行調用
2. 編譯生成.so文件供python程序調用
在linux環境下使用gcc對adder.c進行編譯
命令: gcc adder_plus.cpp -fPIC -shared -o adder_plus.so
3. 在python文件中調用.so
創建一個python文件,命名為adder_plus.py,代碼如下:
from ctypes import *add_plus = CDLL('./add_pluse.so')sum = add_plus.add_integer_plus(4,5)print("sum: " + str(sum))# 使用float類型變量作為函數參數a = c_float(5.5)b = c_float(4.1)add_float = add_plus.add_float_plusadd_float.restype = c_floatsum_float = add_plus.add_float_plus(a,b)print(sum_float)然后在終端里執行命令: python adder_plus.py
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對武林站長站的支持。如果你想了解更多相關內容請查看下面相關鏈接
新聞熱點
疑難解答