【python】PyQt5对象类型的判定,对象删除操作详细解读

✨✨ 欢迎大家来到景天科技苑✨✨

🎈🎈 养成好习惯,先赞后看哦~🎈🎈

🏆 作者简介:景天科技苑

🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。

🏆《博客》:Python全栈,前后端开发,小程序开发,云原生K8S,人工智能,js逆向,App逆向,网络系统安全,数据分析,PyQt5,tkinter,Django,fastapi,flask等框架,linux,shell脚本等实操经验,网站搭建,数据库等分享。

所属的专栏: PyQt5桌面应用开发,零基础到进阶应用实战
景天的主页: 景天科技苑

文章目录

PyQt5类型判定

主要是用来判定一个对象的类型,或者说是否继承自某个类

相关API和应用场景如下

主要有两个方法

  • isWidgetType() 判断某个对象是都控件类型
  • inherits() 一个对象是否继承(直接或间接)自某个父类

两方法返回值均为True或False

类型判断演示

遍历对象,判断对象所属类型和父类

python 复制代码
from PyQt5.Qt import *

class Window(QWidget):
    def __init__(self):
        super().__init__()
        self.setWindowTitle("QObject的学习")
        self.resize(500, 500)
        self.setup_ui()

    def setup_ui(self):

        self.QObject类型判定()

    def QObject类型判定(self):
        # *************API***************开始
        obj = QObject()
        w = QWidget()
        btn = QPushButton()
        label = QLabel()

        objs = [obj, w, btn, label]
        for o in objs:
            print("是否是QWidget的控件类型",o.isWidgetType())
            print("父类是否是QWidget",o.inherits("QWidget"))
            print("父类是否是QPushButton",o.inherits("QPushButton"))
            print("------------------------------------------")
        # *************API***************结束

if __name__ == '__main__':
    import sys
    app = QApplication(sys.argv)

    window = Window()

    window.show()

    sys.exit(app.exec_())

运行。可以判定某个对象所属的类型

PyQt5类型判断案例

根据所属类型, 设置指定的样式

python 复制代码
from PyQt5.Qt import *

class Window(QWidget):
    def __init__(self):
        super().__init__()
        self.setWindowTitle("QObject的学习")
        self.resize(500, 500)
        self.setup_ui()

    def setup_ui(self):

        self.QObject类型判定()
        
    def QObject类型判定(self):
        # *************API***************开始
        # obj = QObject()
        # w = QWidget()
        # btn = QPushButton()
        # label = QLabel()
        #
        # objs = [obj, w, btn, label]
        # for o in objs:
        #     print("是否是QWidget的控件类型",o.isWidgetType())
        #     print("父类是否是QWidget",o.inherits("QWidget"))
        #     print("父类是否是QPushButton",o.inherits("QPushButton"))
        #     print("------------------------------------------")

        # *************API***************结束


        # *************案例***************开始
        label1 = QLabel(self)
        label1.setText("景天科技苑")
        label1.move(100, 100)

        label2 = QLabel(self)
        label2.setText("科技不间断")
        label2.move(150, 150)



        btn = QPushButton(self)
        btn.setText("点我")
        btn.move(200, 200)


        #循环遍历子对象
        # for widget in self.findChildren(QLabel):
        for widget in self.children():
            # print(widget)
            # if widget.isWidgetType():
            #将子对象中为QLabel的对象设置背景样式
            if widget.inherits("QLabel"):
                widget.setStyleSheet("background-color: cyan;")
        # *************案例***************结束

if __name__ == '__main__':
    import sys
    app = QApplication(sys.argv)

    window = Window()

    window.show()

    sys.exit(app.exec_())

运行,QLabel颜色都发生了变化,btn的颜色不变,说明选定了QLabel

PyQt5删除对象

obj.deleteLater()

删除一个对象时, 也会解除它与父对象之间的关系。

deleteLater()并没有将对象立即销毁,而是向主消息循环发送了一个event,下一次主消息循环收到这个event之后才会销毁对象。

这样做的好处是可以在这些延迟删除的时间内完成一些操作,坏处就是内存释放会不及时。

删除对象案例

python 复制代码
from PyQt5.Qt import *

class Window(QWidget):
    def __init__(self):
        super().__init__()
        self.setWindowTitle("QObject的学习")
        self.resize(500, 500)
        self.setup_ui()

    def setup_ui(self):

        self.QObject对象删除()

    def QObject对象删除(self):
        obj1 = QObject()
        #为了防止局部变量运行完方法就销毁,将局部变量赋值给类变量
        self.obj1 = obj1
        obj2 = QObject()
        obj3 = QObject()

        obj3.setParent(obj2)
        obj2.setParent(obj1)

        #创建信号与槽
        obj1.destroyed.connect(lambda : print("obj1被释放了"))
        obj2.destroyed.connect(lambda : print("obj2被释放了"))
        obj3.destroyed.connect(lambda : print("obj3被释放了"))

        #删除对象
        # del obj2  #这样并不能删除
        obj2.deleteLater()
        print(obj1.children())
        #obj2并没有立马被释放
        print("obj2",obj2)
        #执行了deleteLater后,向主消息循环发送了一个event,下一次主消息循环收到这个event之后才会销毁对象,才会真正的去释放相关的对象

if __name__ == '__main__':
    import sys
    app = QApplication(sys.argv)

    window = Window()

    window.show()

    sys.exit(app.exec_())

运行

可以看到obj2并没有立马被删除,立马打印obj1的子对象和obj2还是能打印出来的

过一段时间,obj2才被删除

相关推荐
m0_738120729 小时前
渗透基础知识ctfshow——Web应用安全与防护(完结:第八章)
前端·python·sql·安全·web安全·网络安全
雷帝木木9 小时前
Python 并发编程高级技巧详解:从原理到实践
人工智能·python·深度学习·机器学习
devnullcoffee9 小时前
亚马逊 Movers and Shakers 数据采集实战:用 Python + Scrape API 构建实时榜单监控系统
python·亚马逊数据采集·scrape api·亚马逊数据 api·pangolinfo api·amazon 爬虫工具·实时榜单监控
一个天蝎座 白勺 程序猿9 小时前
AI入门踩坑实录:我换了3种语言才敢说,Python真的是入门唯一选择吗?
开发语言·人工智能·python·ai
Hui_AI7209 小时前
保险条款NLP解析与知识图谱搭建:让AI准确理解保险产品的技术方案
开发语言·人工智能·python·算法·自然语言处理·开源·开源软件
雷帝木木9 小时前
Python Web 框架对比与实战:Django vs Flask vs FastAPI
人工智能·python·深度学习·机器学习
万粉变现经纪人9 小时前
如何解决 pip install jaxlib[cuda] 报错 CUDA 版本与轮子标签不匹配 问题
人工智能·python·深度学习·tensorflow·pandas·scikit-learn·pip
杜子不疼.9 小时前
用 Python 搭建本地 AI 问答系统:避开 90% 新手都会踩的环境坑
开发语言·人工智能·python
源码之家9 小时前
计算机毕业设计源码:京东商品数据采集分析可视化系统python Django Selenium爬虫 人工智能 大数据(建议收藏)✅
人工智能·爬虫·python·信息可视化·数据分析·django·课程设计
生信小窝9 小时前
081B 基于R包-Ecospat的生态位重叠分化迁移分析与可视化制图(单物种和多物种版本)【2027】
人工智能·python·r语言