c++调python接口

1. 新建run.py文件,并定义相关接口:

import numpy as np
from scipy.fftpack import fft

def  str_add(str1,str2):
	return int(str1) + int(str2)

def my_sort(data):
	data.sort()
	return data

def aw_fft(data, Fs):
	N = len(data)
	result = np.abs(fft(x=data, n=N) / N) * 2
	axisFreq = np.arange(int(N / 2)) * Fs / N
	result = result[range(int(N / 2))]
	idx = np.argmax(result)
	return axisFreq[idx]

2. 将run.py文件拷入c++工程目录下:

  • 项目->属性->VC++目录->包含目录->添加python头文件路径(C:\Python38\include);
  • 链接器->常规->附加库目录->添加python库路径(C:\Python38\libs);
  • 链接器->输入->输入python38.lib;

2.1 c++中直接运行python代码

#include <Python.h>
#include <iostream>
#include <math.h>
using namespace std;

int main()
{
    // 初始化Python解释器
    Py_Initialize();
    // 检查初始化是否成功
    if (!Py_IsInitialized()) {
        return -1;
    }
    // 直接运行Python代码
    PyRun_SimpleString("import numpy as np\n");
    PyRun_SimpleString("print(np.sort(np.array([3,2,5,8,1])))");
    // 结束python运行环境
    Py_Finalize();
}

 2.2 c++中调run.py中的str_add接口

#include <Python.h>
#include <iostream>
#include <math.h>
using namespace std;

int main()
{
    PyObject* pModule;
    PyObject* pFun;
    PyObject* pResult;
    PyObject* pArgs;

    // 初始化Python解释器
    Py_Initialize();
    // 检查初始化是否成功
    if (!Py_IsInitialized()) {
        return -1;
    }
    // 定位到python脚本所在目录
    PyRun_SimpleString("import sys\n");
    PyRun_SimpleString("sys.path.append('.')\n");
    // 导入py文件,文件名即可,不需要带后缀.py
    pModule = PyImport_ImportModule("run");
    if (!pModule) {
        printf("error1\n");
        exit(0);
    }
    // 获取模块中函数
    pFun = PyObject_GetAttrString(pModule, "str_add");
    if (!pFun) {
        printf("error2\n");
        exit(0);
    }
    // 创建参数
    string s1 = "33";
    string s2 = "66";
    pArgs = Py_BuildValue("(ss)", s1.c_str(), s2.c_str());
    // 调用函数
    pResult = PyObject_CallFunction(pFun, "O", pArgs);
    int res = PyLong_AsLong(pResult);
    printf("result=%d\n", res);

    // 使用结束后,释放掉这些Python对象
    Py_DECREF(pModule);
    Py_DECREF(pFun);
    Py_DECREF(pResult);
    Py_DECREF(pArgs);
    // 结束python运行环境
    Py_Finalize();

    return 0;
}

 2.3 c++中调run.py中的my_sort接口

#include <Python.h>
#include <iostream>
#include <math.h>
using namespace std;

int main()
{
    PyObject* pModule;
    PyObject* pFun;
    PyObject* pResult;
    PyObject* pArgs;

    // 初始化Python解释器
    Py_Initialize();
    // 检查初始化是否成功
    if (!Py_IsInitialized()) {
        return -1;
    }
    // 定位到python脚本所在目录
    PyRun_SimpleString("import sys\n");
    PyRun_SimpleString("sys.path.append('.')\n");
    // 导入py文件,文件名即可,不需要带后缀.py
    pModule = PyImport_ImportModule("run");
    if (!pModule) {
        printf("error1\n");
        exit(0);
    }
    // 获取模块中函数
    pFun = PyObject_GetAttrString(pModule, "my_sort");
    // 创建参数
    pArgs = Py_BuildValue("[i,i,i,i,i]", 4,2,6,3,1);
    pResult = PyObject_CallFunction(pFun, "O", pArgs);
    printf("result=%d\n", PyList_Size(pResult));
    for (int i = 0; i < PyList_Size(pResult); i++) {
        PyObject* b = PyList_GetItem(pResult, i);
        int bi = _PyLong_AsInt(b);
        cout << bi << endl;
    }

    // 使用结束后,释放掉这些Python对象
    Py_DECREF(pModule);
    Py_DECREF(pFun);
    Py_DECREF(pResult);
    Py_DECREF(pArgs);
    // 结束python运行环境
    Py_Finalize();

    return 0;
}

2.4 c++中调run.py中的aw_fft接口 

#include <Python.h>
#include <iostream>
#include <math.h>
using namespace std;

int main()
{
    PyObject* pModule;
    PyObject* pFun;
    PyObject* pResult;
    PyObject* pArgs;

    // 初始化Python解释器
    Py_Initialize();
    // 检查初始化是否成功
    if (!Py_IsInitialized()) {
        return -1;
    }
    // 定位到python脚本所在目录
    PyRun_SimpleString("import sys\n");
    PyRun_SimpleString("sys.path.append('.')\n");
    // 导入py文件,文件名即可,不需要带后缀.py
    pModule = PyImport_ImportModule("run");
    if (!pModule) {
        printf("error1\n");
        exit(0);
    }
    // 获取模块中函数
    pFun = PyObject_GetAttrString(pModule, "aw_fft");
    if (!pFun) {
        printf("error2\n");
        exit(0);
    }
    PyObject* list = PyList_New(1000);
    for (int i = 0; i < 1000; i++) {
        double temp = sin(2 * 3.14 * 235 * i / 6000);
        PyList_SetItem(list, i, PyFloat_FromDouble(temp)); 
    }
    PyObject* Fs = Py_BuildValue("i", 6000);
    pArgs = PyTuple_Pack(2, list, Fs);
    pResult = PyObject_CallFunction(pFun, "O", pArgs);
    printf("%.2f\n", PyFloat_AsDouble(pResult));

    // 使用结束后,释放掉这些Python对象
    Py_DECREF(pModule);
    Py_DECREF(pFun);
    Py_DECREF(pResult);
    Py_DECREF(pArgs);
    // 结束python运行环境
    Py_Finalize();

    return 0;
}

 

 3. c++中将python接口编译dll文件

在dllmain.cpp中添加如下接口:

#include "utils.h"
#include <Python.h>
#include <iostream>

float aw_fft(const char* py_name, const char* fun_name, double* data, int data_cnts, int Fs)
{
    PyObject* pModule;
    PyObject* pFun;
    PyObject* pArgs;
    PyObject* pResult;
    // 初始化Python解释器
    Py_Initialize();
    // 检查初始化是否成功
    if (!Py_IsInitialized()) {
        return -1;
    }
    // 定位到脚本所在目录
    PyRun_SimpleString("import sys\n");
    PyRun_SimpleString("sys.path.append('.')\n");
    // 导入py文件,写文件名即可,不需要带后缀.py
    pModule = PyImport_ImportModule("run");
    if (!pModule) {
        printf("error1\n");
        exit(0);
    }
    // 获取模块中函数
    pFun = PyObject_GetAttrString(pModule, "aw_fft");
    if (!pFun) {
        printf("error2\n");
        exit(0);
    }

    // 创建列表对象
    PyObject* list = PyList_New(data_cnts);
    for (int i = 0; i < data_cnts; i++) {
        PyList_SetItem(list, i, PyFloat_FromDouble(data[i]));
    }
    // 创建整形对象
    PyObject* sample = Py_BuildValue("i", Fs);
    // 创建参数
    pArgs = PyTuple_Pack(2, list, sample);
    // 调用函数
    pResult = PyObject_CallFunction(pFun, "O", pArgs);
    float result = PyFloat_AsDouble(pResult);

    // 释放对象
    Py_DECREF(pModule);
    Py_DECREF(pFun);
    Py_DECREF(pResult);
    Py_DECREF(pArgs);
    // 结束python运行环境
    Py_Finalize();
    return result;
}

新建utils.h文件:

#define CREATDLL_EXPORTS

#ifdef CREATDLL_EXPORTS
#define DLL_API __declspec(dllexport)  
#else
#define DLL_API __declspec(dllimport)  
#endif

extern "C" DLL_API void add_fun(int a, int b, int& c);
extern "C" DLL_API float aw_fft(const char* py_name, const char* fun_name, double* data, int data_cnts, int Fs);

生成解决方案,生成lib和dll文件,将util.h及Dll1.lib和Dll.dll文件拷入c++工程供调用:

#include <iostream>
#include"utils.h"

using namespace std;

#pragma comment	(lib, "Dll1.lib")
int main()
{
    double data[1000] = { 0 };
   for (int i = 0; i < 1000; i++) {
       data[i]= sin(2 * 3.14 * 235 * i / 6000);
   }
   const char* py_name = "run";
   const char* fun_name = "aw_fft";
   float res = aw_fft(py_name, fun_name, data, 1000, 6000);
   cout << res << endl;
}

c++能调用python的接口吗 c++调用python程序 

  • 5
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Python中,要调用C语言的回函数,需要使用ctypes库。ctypes是Python的外部函数库,它提供了与C语言库函数交互的接口。 首先,我们需要在Python代码中导入ctypes库,以便使用其功能。 接下来,我们需要定义一个C语言回函数,并通过ctypes的CFUNCTYPE函数声明函数类型和参数类型。然后,我们将C语言回函数的指针传递给Python函数。 在Python中,我们可以使用ctypes.CDLL函数加载C语言动态链接库,并通过函数名调用C语言回函数。 下面是一个简单的示例代码,演示了如何在Python调用C语言的回函数: import ctypes # 定义C语言回函数 def my_callback_function(number): print("C语言回函数被调用,传递的参数是:", number) # 声明C语言回函数的类型 CallbackFunc = ctypes.CFUNCTYPE(None, ctypes.c_int) # 将Python函数转换为C语言回函数 c_callback = CallbackFunc(my_callback_function) # 加载C语言动态链接库 c_lib = ctypes.CDLL("my_c_lib.so") # 假设my_c_lib.so是C语言动态链接库 # 调用C语言回函数 c_lib.call_callback(c_callback) 在上面的示例中,我们定义了一个名为my_callback_function的Python函数作为C语言回函数。然后,我们使用CFUNCTYPE函数声明了C语言回函数的类型,指定了参数类型和返回类型。 通过CallbackFunc函数将Python函数转换为C语言回函数,并将其传递给C语言动态链接库中的call_callback函数。 当C语言动态链接库中的call_callback函数被调用时,C语言回函数会被执行,同时将参数传递给Python中的my_callback_function函数。 这样,我们就可以在Python中成功调用C语言的回函数了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

东城青年

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值