QT中调用python

一.概述

1.Python功能强大,很多Qt或者c/c++开发不方便的功能可以由Python编码开发,尤其是一些算法库的应用上,然后Qt调用Python。

2.在Qt调用Python的过程中,必须要安装python环境,并且Qt Creator中编译器与Python的版本要对应,具体来说编译器是64位安装Python就是64位,编译器32位安装Python就是32位。

3.本文测试使用的QT版本为:QT5.12;  python版本为python-3.12

4.Qt调用python主要有两种方式:

一是混合编程模式,直接调用python文件内的函数,比较灵活,也是本文重点讲述的方法;

二是直接调用python脚本文件,比较简单,但是不够灵活。

二.混合编程代码实现

1.环境配置

(1)pro文件中添加python的头文件和依赖库:

INCLUDEPATH += -I D:\python\Lib\site-packages\numpy\core\include

INCLUDEPATH += -I D:\python\include

LIBS += -L D:\python\libs -l_tkinter -lpython3 -lpython312

(2)修改include文件夹中的object.h文件,因为Python中slots是关键字,Qt中slots也是关键字,会冲突。

#undef slots

    PyType_Slot *slots; /* terminated by slot==0. */

#define slots Q_SLOTS  

2.代码实现

(1)Python代码添加目录及内容

添加test1.py文件到qt生成exe目录,比如:

../build-qt_python-Desktop_Qt_5_12_10_MinGW_64_bit-Debug/debug/testb.py

否则无法调用py文件。

Python代码:

def hello():

    print("hello")

def mix(a,b):

    print("=======================")

    r1 = a + b

    r2 = a - b

return (r1, r2)

2.qt代码

#include <QCoreApplication>

#include <Python.h>

#include <QDebug>

#include <numpy/arrayobject.h>

int Test_hello(void)

{

    //初始化python模块

    Py_Initialize();

    if ( !Py_IsInitialized() )

    {

        return -1;

    }

    //导入testb.py模块

    PyObject* pModule = PyImport_ImportModule("testb");

    if (!pModule) {

        qDebug("Cant open python file!\n");

        return -1;

    }

    //获取test模块中的hello函数

    PyObject* pFunhello= PyObject_GetAttrString(pModule,"hello");

    if(!pFunhello){

        qDebug()<<"Get function hello failed";

        return -1;

    }

    //调用hello函数

    PyObject_CallFunction(pFunhello,NULL);

    //结束,释放python

    Py_Finalize();

    return 0;

}

int Testt_mix(void)

{

    //初始化python模块

    Py_Initialize();

    if ( !Py_IsInitialized() )

    {

        return -1;

    }

    PyObject* pModule = PyImport_ImportModule("testb");//注意文件名字大小写

    if (!pModule) {

        qDebug("Cant open python file!\n");

        return -1;

    }

    PyObject* pyFunc_mix = PyObject_GetAttrString(pModule, "mix");

    if (pModule && PyCallable_Check(pyFunc_mix))

    {

        PyObject* pyParams = PyTuple_New(2); //定义两个变量

        PyTuple_SetItem(pyParams, 0, Py_BuildValue("i", 5));// 变量格式转换成python格式

        PyTuple_SetItem(pyParams, 1, Py_BuildValue("i", 2));// 变量格式转换成python格式

        int r1 = 0, r2 = 0;

        PyObject* pyValue = PyObject_CallObject(pyFunc_mix, pyParams); //调用函数返回结果

        PyArg_ParseTuple(pyValue, "i|i", &r1, &r2);//分析返回的元组值

        if (pyValue)

        {

            qDebug("result: %d   %d\n", r1, r2);

        }

    }

    //结束,释放python

    Py_Finalize();

    return 0;

}

int main(int argc, char *argv[])

{

    QCoreApplication a(argc, argv);

    Test_hello();

    Testt_mix();

   return a.exec();

}

3.输出结果

三.直接调用python脚本模式

1.python文件

import sys

def test():

    a = 1

    print (a)

if __name__=='__main__':

   b = test()

   print (b)

2.QT代码

      //第一步:初始化Python

      Py_Initialize();

      //检查初始化是否完成

      if (!Py_IsInitialized())

      {

          return -1;

      }

      //第二步:导入sys模块

      PyRun_SimpleString("import sys");

      const char* code = "with open('./debug/scriptpy.py', 'r') as file: exec(file.read())";

      // 执行代码字符串

      if (PyRun_SimpleString(code) != 0)

      {

          // 处理错误

          PyErr_Print();

          return -1;

      }

      Py_Finalize();

3.执行结果

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/485627.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何理解跨境ERP定制中的技术要点与挑战?

在跨境电商领域日益竞争激烈的今天&#xff0c;企业需要依靠先进的ERP系统来实现信息管理、数据整合和业务流程优化。而针对不同国家和地区的特殊需求&#xff0c;跨境ERP定制越来越成为企业必须面对的挑战。本文将深入探讨跨境ERP定制中的技术要点与挑战&#xff0c;帮助企业更…

缓存篇—缓存雪崩

什么是缓存雪崩 通常我们为了保证缓存中的数据与数据库中的数据一致性&#xff0c;会给 Redis 里的数据设置过期时间&#xff0c;当缓存数据过期后&#xff0c;用户访问的数据如果不在缓存里&#xff0c;业务系统需要重新生成缓存&#xff0c;因此就会访问数据库&#xff0c;并…

windows如何恢复删除文件?「2024恢复策略」

在数字时代&#xff0c;数据无疑是最为宝贵的财富之一。然而&#xff0c;无论是因为误操作、病毒感染还是其他各种原因&#xff0c;我们时常会面临文件被误删的风险。当重要的文件从Windows系统中消失时&#xff0c;许多用户都会感到焦虑和无助。那么&#xff0c;Windows系统下…

CSS 面试题汇总

CSS 面试题汇总 1. 介绍下 BFC 及其应 参考答案&#xff1a; 参考答案&#xff1a; 所谓 BFC&#xff0c;指的是一个独立的布局环境&#xff0c;BFC 内部的元素布局与外部互不影响。 触发 BFC 的方式有很多&#xff0c;常见的有&#xff1a; 设置浮动overflow 设置为 auto、scr…

SWIFT:自我认知微调

文档:https://github.com/modelscope/swift/blob/main/docs/source/LLM/%E8%87%AA%E6%88%91%E8%AE%A4%E7%9F%A5%E5%BE%AE%E8%B0%83%E6%9C%80%E4%BD%B3%E5%AE%9E%E8%B7%B5.md ​​​​​​代码: Swift是如何把自我认知数据集融合到训练集中呢? 1:相关的3个参数

【Linux】一站式教会:Ubuntu(无UI界面)使用apache-jmeter进行压测

&#x1f3e1;浩泽学编程&#xff1a;个人主页 &#x1f525; 推荐专栏&#xff1a;《深入浅出SpringBoot》《java对AI的调用开发》 《RabbitMQ》《Spring》《SpringMVC》 &#x1f6f8;学无止境&#xff0c;不骄不躁&#xff0c;知行合一 文章目录 前言一、Java…

【深度学习目标检测】十八、基于深度学习的人脸检测系统-含GUI和源码(python,yolov8)

人脸检测是计算机视觉中的一个重要方向&#xff0c;也是一个和人们生活息息相关的研究方向&#xff0c;因为人脸是人最重要的外貌特征。人脸检测技术的重要性主要体现在以下几个方面&#xff1a; 人脸识别与安全&#xff1a;人脸检测是人脸识别系统的一个关键部分&#xff0c;是…

【了解机器学习的定义与发展历程】

曾梦想执剑走天涯&#xff0c;我是程序猿【AK】 目录 简述概要知识图谱 简述概要 了解机器学习的定义与发展历程 知识图谱 机器学习&#xff08;Machine Learning&#xff0c;ML&#xff09;是一门跨学科的学科&#xff0c;它使用计算机模拟或实现人类学习行为&#xff0c;通…

我们在SqlSugar开发框架中,用到的一些设计模式

我们在《SqlSugar开发框架》中&#xff0c;有时候都会根据一些需要引入一些设计模式&#xff0c;主要的目的是为了解决问题提供便利和代码重用等目的。而不是为用而用&#xff0c;我们的目的是解决问题&#xff0c;并在一定的场景下以水到渠成的方式处理。不过引入任何的设计模…

隐藏饿了么el-select组件的el-select-dropdown部分,只使用el-select的显示框

隐藏饿了么el-select组件的el-select-dropdown部分,只使用el-select的显示框 问题: 由于el-select组件的el-select-dropdown部分是自动插入在最外层Body上的&#xff0c;所以在当前组件的scoped中让el-select-dropdown组件display:none不会生效所以需要&#xff1a; :popper-…

使用ffmpeg实现视频片段截取并保持清晰度

1 原始视频信息 通过ffmpeg -i命令查看视频基本信息 ffmpeg -i input.mp4 ffmpeg version 6.1-essentials_build-www.gyan.dev Copyright (c) 2000-2023 the FFmpeg developersbuilt with gcc 12.2.0 (Rev10, Built by MSYS2 project)configuration: --enable-gpl --enable-ve…

【学习笔记】数据结构与算法03:栈与队列

知识出处&#xff1a;Hello算法&#xff1a;https://www.hello-algo.com/. 文章目录 2.2 栈和队列2.2.1 「栈 stack」2.2.1.1 栈的常用操作2.2.1.2 栈的典型应用 2.2.2「队列 queue」2.2.2.1 队列的常用操作2.2.2.2 队列的典型应用 2.2.3 双向队列 「double-ended queue」2.2.3…