pyside6的信号与槽的简单测试

2024-05-10 20:20
文章标签 简单 测试 信号 pyside6

本文主要是介绍pyside6的信号与槽的简单测试,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

from PySide6.QtCore import QObject, Signal, QCoreApplication
import sysdef handle_signal(arg1, arg2):print("Received objects:", arg1, arg2)class UI(QObject):  # 创建QObject,用来承载和定义信号signal1 = Signal(object, object)  # 定义信号,为了提高灵活性,并没有定义信号的具体数据类型,而是定义为了objectdef __init__(self):super().__init__()self.signal1.emit('a', 100.0)    # 发射信号if __name__ == "__main__":app = QCoreApplication(sys.argv)ui = UI()ui.signal1.connect(handle_signal)    # 信号的连接sys.exit(app.exec())

运行结果,并没有正确执行。尽管这个信号被发射了,但在此时还没有槽连接到这个信号,因此没有任何效果。

修改,将槽的连接定义移至发射前面:原则上,先定义槽连接,再发射信号。

from PySide6.QtCore import QObject, Signal, QCoreApplication
import sysdef handle_signal(arg1, arg2):print("Received objects:", arg1, arg2)class UI(QObject):  # 创建QObject,用来承载和定义信号signal1 = Signal(object, object)  # 定义信号,为了提高灵活性,并没有定义信号的具体数据类型,而是定义为了objectdef __init__(self):super().__init__()if __name__ == "__main__":app = QCoreApplication(sys.argv)ui = UI()ui.signal1.connect(handle_signal)    # 信号的连接ui.signal1.emit('a', 100.0)  # 发射信号sys.exit(app.exec())# 运行结果:Received objects: a 100.0

 进一步的,发射和接收参数的数量:

信号定义了2个参数,只发射了1个,出错。

from PySide6.QtCore import QObject, Signal, QCoreApplication
import sysdef handle_signal(arg1, arg2):print("Received objects:", arg1, arg2)class UI(QObject):  # 创建QObject,用来承载和定义信号signal1 = Signal(object, object)  # 定义信号,为了提高灵活性,并没有定义信号的具体数据类型,而是定义为了objectdef __init__(self):super().__init__()if __name__ == "__main__":app = QCoreApplication(sys.argv)ui = UI()ui.signal1.connect(handle_signal)    # 信号的连接ui.signal1.emit('a')  # 发射信号sys.exit(app.exec())
# 出错信息:
TypeError: signal1(PyObject,PyObject) needs 2 argument(s), 1 given!

信号定义了3个参数,发射了3个,只接收2个,可以的。

from PySide6.QtCore import QObject, Signal, QCoreApplication
import sysdef handle_signal(arg1, arg2):print("Received objects:", arg1, arg2)class UI(QObject):  # 创建QObject,用来承载和定义信号signal1 = Signal(object, object, object)  # 定义信号,为了提高灵活性,并没有定义信号的具体数据类型,而是定义为了objectdef __init__(self):super().__init__()if __name__ == "__main__":app = QCoreApplication(sys.argv)ui = UI()ui.signal1.connect(handle_signal)    # 信号的连接ui.signal1.emit('a', 100.0, 123)  # 发射信号sys.exit(app.exec())# 运行结果:Received objects: a 100.0

总结:发射的参数必须按照信号的定义数量,槽函数接收的参数数量可以比定义的数量少。

可能的应用场景:PLC通信,上位机接收到PLC发送的数据包之后,第一个数据单元可能规定了数据的参数,第二个数据单元可能是数据的具体内容。

demo:

 

from PySide6.QtCore import QObject, Signal, QCoreApplication
import sysdef analysis_signal(arg1, arg2):   # 解析PLC数据print("Received datas:", arg1, "\nLength of datas:", arg2)def datas_signal(*args):     #  拆包数据print("Datas is:", *args[2:])class UI(QObject):  # 创建QObject,用来承载和定义信号signal1 = Signal(object, object, object)  # 定义信号,为了提高灵活性,并没有定义信号的具体数据类型,而是定义为了objectdef __init__(self):super().__init__()if __name__ == "__main__":app = QCoreApplication(sys.argv)ui = UI()ui.signal1.connect(analysis_signal)    # 信号的连接ui.signal1.connect(datas_signal)datas = ('a1', 5, (0xfe, 100, 200, 200.0, 123))  # 数据包demo,a1的含义:来自PLC1的数据;5:数据长度;(0xfe, 100, 200, 200.0, 123):数据包具体内容。ui.signal1.emit(*datas)  # 发射信号sys.exit(app.exec())# 运行结果:
Received datas: a1 
Length of datas: 5
Datas is: (254, 100, 200, 200.0, 123)

这篇关于pyside6的信号与槽的简单测试的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/977461

相关文章

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

字节面试 | 如何测试RocketMQ、RocketMQ?

字节面试:RocketMQ是怎么测试的呢? 答: 首先保证消息的消费正确、设计逆向用例,在验证消息内容为空等情况时的消费正确性; 推送大批量MQ,通过Admin控制台查看MQ消费的情况,是否出现消费假死、TPS是否正常等等问题。(上述都是临场发挥,但是RocketMQ真正的测试点,还真的需要探讨) 01 先了解RocketMQ 作为测试也是要简单了解RocketMQ。简单来说,就是一个分

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

hdu2289(简单二分)

虽说是简单二分,但是我还是wa死了  题意:已知圆台的体积,求高度 首先要知道圆台体积怎么求:设上下底的半径分别为r1,r2,高为h,V = PI*(r1*r1+r1*r2+r2*r2)*h/3 然后以h进行二分 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#includ

usaco 1.3 Prime Cryptarithm(简单哈希表暴搜剪枝)

思路: 1. 用一个 hash[ ] 数组存放输入的数字,令 hash[ tmp ]=1 。 2. 一个自定义函数 check( ) ,检查各位是否为输入的数字。 3. 暴搜。第一行数从 100到999,第二行数从 10到99。 4. 剪枝。 代码: /*ID: who jayLANG: C++TASK: crypt1*/#include<stdio.h>bool h

【测试】输入正确用户名和密码,点击登录没有响应的可能性原因

目录 一、前端问题 1. 界面交互问题 2. 输入数据校验问题 二、网络问题 1. 网络连接中断 2. 代理设置问题 三、后端问题 1. 服务器故障 2. 数据库问题 3. 权限问题: 四、其他问题 1. 缓存问题 2. 第三方服务问题 3. 配置问题 一、前端问题 1. 界面交互问题 登录按钮的点击事件未正确绑定,导致点击后无法触发登录操作。 页面可能存在

uva 10387 Billiard(简单几何)

题意是一个球从矩形的中点出发,告诉你小球与矩形两条边的碰撞次数与小球回到原点的时间,求小球出发时的角度和小球的速度。 简单的几何问题,小球每与竖边碰撞一次,向右扩展一个相同的矩形;每与横边碰撞一次,向上扩展一个相同的矩形。 可以发现,扩展矩形的路径和在当前矩形中的每一段路径相同,当小球回到出发点时,一条直线的路径刚好经过最后一个扩展矩形的中心点。 最后扩展的路径和横边竖边恰好组成一个直

业务中14个需要进行A/B测试的时刻[信息图]

在本指南中,我们将全面了解有关 A/B测试 的所有内容。 我们将介绍不同类型的A/B测试,如何有效地规划和启动测试,如何评估测试是否成功,您应该关注哪些指标,多年来我们发现的常见错误等等。 什么是A/B测试? A/B测试(有时称为“分割测试”)是一种实验类型,其中您创建两种或多种内容变体——如登录页面、电子邮件或广告——并将它们显示给不同的受众群体,以查看哪一种效果最好。 本质上,A/B测

poj 1113 凸包+简单几何计算

题意: 给N个平面上的点,现在要在离点外L米处建城墙,使得城墙把所有点都包含进去且城墙的长度最短。 解析: 韬哥出的某次训练赛上A出的第一道计算几何,算是大水题吧。 用convexhull算法把凸包求出来,然后加加减减就A了。 计算见下图: 好久没玩画图了啊好开心。 代码: #include <iostream>#include <cstdio>#inclu

uva 10130 简单背包

题意: 背包和 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <queue>#include <map>