- Java锁的逻辑(结合对象头和ObjectMonitor)
- 还在用饼状图?来瞧瞧这些炫酷的百分比可视化新图形(附代码实现)⛵
- 自动注册实体类到EntityFrameworkCore上下文,并适配ABP及ABPVNext
- 基于Sklearn机器学习代码实战
在 PyQt 开发中,时常需要对控件的值进行校验,如需要校验 QCheckBox 是否被选中, QLabel 是否校验值是否为空等等。在复杂的业务场景下,这类控件如果数量很多,逐个校验就显得麻烦,需要一一获得控件名称,再调用对应的方法来判断是否被选中、是否为空等。而且开发过程中如果多控件做了增减,还需要增减校验的逻辑,那会要了老命.
此篇文章,推荐使用 __dict__ 属性 + 字典映射来快速校验控件值,并且无视后面控件的增减,无需调整代码.
__dict__
是什么? 做 python 开发的,或多或少都接触过该属性,它是 类 独有的一个特性,用来保存 类 的一些属性,关于这个属性的相关文章,网上一抓一大把,此处不作赘述,需要说明的是, 类实例 也有自己的 __dict__ 属性,而且和 类 的 __dict 不同,``类实例 的 dict 只保存了通过 self.xxx`所声明的属性和方法.
接下来的演示中,仅使用 QCheckBox (为了省事),同时要保持这些控件的名称要具备同样的特征,下面的截图中,所有的控件名称都以 checkbox 结尾.
1、使用 .ui 文件生成 .py 文件 。
2、简单写个入口程序 。
继承刚才生成的 .py 文件,在这里可以实现自己的方法,在自定义类中,先打印 __dict__ ,看看有哪些值.
{
'centralwidget': <PyQt6.QtWidgets.QWidget object at 0x00000231DD4E9D30>,
'gridLayout': <PyQt6.QtWidgets.QGridLayout object at 0x00000231DD4E9DC0>,
'c_checkbox': <PyQt6.QtWidgets.QCheckBox object at 0x00000231DD4E9E50>,
'd_checkbox': <PyQt6.QtWidgets.QCheckBox object at 0x00000231DD4E9EE0>,
'a_checkbox': <PyQt6.QtWidgets.QCheckBox object at 0x00000231DD4E9F70>,
'b_checkbox': <PyQt6.QtWidgets.QCheckBox object at 0x00000231DD9A3040>,
'f_checkbox': <PyQt6.QtWidgets.QCheckBox object at 0x00000231DD9A30D0>,
'e_checkbox': <PyQt6.QtWidgets.QCheckBox object at 0x00000231DD9A3160>,
'menubar': <PyQt6.QtWidgets.QMenuBar object at 0x00000231DD9A31F0>,
'statusbar': <PyQt6.QtWidgets.QStatusBar object at 0x00000231DD9A3280>
}
可以看到,它是一个字典,它包含了界面上所有的控件的名称和实例对象,这里就体现出了控件名称命名时遵守统一特征的好处了,即能望文生义,也方便处理.
3、提取所有 QCheckBox 的控件名称,构建一个校验的通用逻辑 。
import sys
from PyQt6.QtWidgets import QMainWindow, QApplication, QCheckBox
from ui_main import Ui_MainWindow
class MainWindow(Ui_MainWindow, QMainWindow):
def __init__(self):
super().__init__()
super().setupUi(self)
self.show()
self.checkboxs()
def checkboxs(self):
# print(self.__dict__)
# 增加这个字典映射是为了可以自动处理更多类型的控件值校验
widget_mapping = {
'QCheckBox': QCheckBox.isChecked
}
# 获取所有QCheckBox的控件名称
boxs = [
item for item in self.__dict__ \
if item.endswith('_checkbox')
]
# 用来保存未被勾选的控件
un_checked = []
for item in boxs:
widget_instance = self.__dict__.get(item)
widget_method = widget_mapping.get(
self.__dict__.get(item).__class__.__name__
)
# 如果该QCheckBox处于未选中,则被添加到列表中
if not widget_method(widget_instance):
un_checked.append(item)
print(un_checked)
if __name__ == '__main__':
app = QApplication(sys.argv)
window = MainWindow()
sys.exit(app.exec())
4、逻辑分析 。
(1) 在代码 。
boxs = [
item for item in self.__dict__ \
if item.endswith('_checkbox')
]
中,通过 __dict__ 提取了所有以 _checkbox 结尾的控件名称,注意,这只是字符串而已,并非控件本身.
(2)构建一个通用的控件名称和控件方法的字典映射 。
# 增加这个字典映射是为了可以自动处理更多类型的控件值校验
widget_mapping = {
'QCheckBox': QCheckBox.isChecked
}
这么做的目的是为了让这个逻辑更具通用性,让这个逻辑兼容其他控件,简单来说,可以通过控件的名称(boxs列表)找到该控件对应的方法,因为每个控件获取值所用的方法不尽相同.
(3)遍历 boxs 列表,逐个去 widget_mapping 找对应的方法,假如这里要较多种控件的话,字典映射的优势就体现出来了。 widget_method 就是该控件获取值所要用的方法了, QCheckBox 控件,就用 isChecked 方法来获取控件是否被选中.
(4)调用所找到的方法 widget_method 。这里之所以要把控件实例 widget_instance 传入方法中,是因为控件方法 isChecked 是单独调用的,它默认要传入 self参数 即实例本身.
运行代码看看效果 。
可以看到6个选项均为选中,打印结果符合该事实.
在 qt desinger 中默认勾选两个,再试试效果 。
有4个未选中,打印结果符合事实.
上面的仅为演示代码,只是演示处理此类问题的逻辑,刚构建逻辑时会显得很绕,但是构建起来后就很好用了,如果再渐增控件,只要遵守控件名称命名规范,那么所增加的控件校验也无需增加校验代码,减少控件也一样.
如果一个界面中有很多控件需要填写数值或清空数值,如:
一样可以使用这个逻辑进行处理,只要前期构建好,代码复用完全不是问题.
最后此篇关于香,一套逻辑轻松且智能解决PyQt中控件数值验证的问题的文章就讲到这里了,如果你想了解更多关于香,一套逻辑轻松且智能解决PyQt中控件数值验证的问题的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我尝试将resteasy与自定义对象一起使用,当我创建jar文件时,它与intellij IDE一起工作正常,但失败并出现以下异常 org.jboss.resteasy.core.NoMessageB
我正在寻找一种在easy-close选项为TRUE时基于Shiny模态关闭触发事件的方法(因此,在模态外部单击将其关闭)。由于没有链接到模式的ID,因此我似乎无法捕获此事件。我尝试在“观察”事件中包装
假设我有一些定义如下的类: class Security { Boolean AuthenticateUser(String username, String password); B
正如标题所说,Coq 可以用作模型检查器吗?我可以将模型检查与 Coq 证明混合使用吗?这是常态吗?谷歌谈论“微积分”,有没有人有这方面的经验或类似的经验?是否建议以这种方式使用 Coq,或者我应该寻
是否有一种方法(设置或快捷方式)可以显示输出超过 500 行的查询的总行数 - 即,无需修改首选项中的“结果集页面大小”值?我本质上是在寻找 select count(*) from () t 的输出
我想这样做: System.out.println("안녕하세요!"); 但是当我尝试在 Eclipse 中进行编译时,出现“某些字符无法使用 MacRoman 字符编码进行编码”弹出式错误消息。我正
如果我有一个用这样的字符串初始化的框架 setter CTFramesetterRef framesetter = CTFramesetterCreateWithAttributedString(at
所以这里没有什么新内容,我只是想得到一些澄清,但似乎在其他帖子中找不到任何澄清。 我正在安静地创建一个新资源,例如: /books (POST) 有一个 body : { title: 'The
我有很多预处理器宏定义,如下所示: #define FOO 1 #define BAR 2 #define BAZ 3 在实际应用中,每个定义对应一个解释器虚拟机中的一条指令。宏的编号也不是连续的,以
使用 SpriteKit 开发 iOS 游戏。我的背景由 map block 组成(本质上是无限 map ,程序生成)。 我们的系统旨在管理 map 的“ block ”,我们只加载玩家附近的 blo
我需要在 Ruby 中拆分一个具有以下格式的字符串: [{a:1,b:2,c:3,d:4},{a:5,b:6,c:7,d:8},{a:9,b:10,c:11,d:12},{a:13,b:14,c:1
Linq 有一个名为 Take() 的便捷运算符方法,可以返回任何实现 IEnumerable 的元素中给定数量的元素。 jQuery 中是否有类似的东西可以处理数组? 或者,换个方式问:如何在 Ja
每当我使用以下代码在文档中插入图像时, var cursor = DocumentApp.getActiveDocument().getCursor(); var image = cursor
今天看到这样一段代码: if ( not defined($reply_address) or not defined($from_name) or not defined(
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
刚刚了解 mercurial 的 --style和 --template可用于 hg log 的选项和 hg tip我发现它们非常有帮助,但我不知道把我的“样式文件”放在哪里 我有一个“样式文件”,它
是否有一些应用程序可以自动 bundle (并缩小)包含 require('file.js') 调用的 JS 项目?这样它们就会合并并生成一个文件。 具体来说,我正在谈论when.js ,一个带有大量
如何(轻松)获取 Sublime Text 3 中的当前文件路径 我不经常使用 ST 控制台(我只使用它一次来安装包管理器),但我认为这可能是一个好方法: 像某种pwd命令一样获取当前文件路径。 但这
嗨,我正在使用resteasy api,我需要使用Map作为QueryParam。我可以使用列表作为 QueryParam,但是当我尝试传递 Map 时,我收到下面提到的错误。 这是我的服务代码 @G
假设我有一个 C++ 代码(请参阅下面的简单示例)。我想让期刊审稿人轻松安装/运行 所以我认为最简单的方法是将其变形为简化的类 R 包的 tar.gz 文件,以便裁判可以安装它通过简单地调用 inst
我是一名优秀的程序员,十分优秀!