Python tkinter库之Toplevel 子窗口与主窗口之间的联系

简介: Python tkinter库之Toplevel 子窗口与主窗口之间的联系

第一次写此类代码,仅是个简单的框架,有待进一步丰富内容。源代码如下:

import tkinter as tk
class Win1Input(tk.Toplevel):
    def __init__(self):
        super().__init__()
        self.title(u'凭证号录入')
        self.geometry('240x150+266+483')
        self.attributes("-toolwindow", 2)
        self.resizable(False,False)
        self.wm_attributes('-topmost',True)
        self.protocol("WM_DELETE_WINDOW", self.cancel)
        self.setup_UI()
    def setup_UI(self):
        global flagWin1
        flagWin1=True
        self.code1 = tk.StringVar()
        self.code2 = tk.IntVar()
        te1=tk.Entry(self, textvariable=self.code1, width=20)
        te2=tk.Entry(self, textvariable=self.code2, width=20)
        te1.place(x=70,y=5)
        te2.place(x=70,y=35)
        tl1=tk.Label(self, text=u'凭证号:', width=8, anchor=tk.E)
        tl2=tk.Label(self, text=u'协议号:', width=8, anchor=tk.E)
        tl1.place(x=5,y=5)
        tl2.place(x=5,y=35)
        tb1=tk.Button(self, text=u"确定", command=self.ok)
        tb2=tk.Button(self, text=u"取消", command=self.cancel)
        tb1.place(x=60,y=80)
        tb2.place(x=150,y=80)
        te1.focus()
    def exit1(self):
        global flagWin1
        flagWin1=False
        print('exitWin1')
        self.destroy()
    def ok(self):
        self.Retcode = [self.code1.get(), self.code2.get()]
        self.exit1()
    def cancel(self):
        self.Retcode = None
        self.exit1()
class Win2Print(tk.Toplevel):
    def __init__(self):
        super().__init__()
        self.title(u'凭证打印')
        self.geometry('400x300+266+483')
        self.attributes("-toolwindow", 2)
        self.resizable(False,False)
        self.wm_attributes('-topmost',True)
        self.protocol("WM_DELETE_WINDOW", self.cancel)
        self.setup_UI()
    def setup_UI(self):
        global flagWin2
        flagWin2=True
        tcv=tk.Canvas(self, width=400, height=220, bg='white')
        tcv.create_text((20, 80), text=u'凭证打印的内容,此处略', anchor=tk.W)
        tcv.place(x=0,y=0)
        tb1=tk.Button(self, text=u"打印", command=self.ok)
        tb2=tk.Button(self, text=u"取消", command=self.cancel)
        tb1.place(x=90,y=250)
        tb2.place(x=200,y=250)
    def exit2(self):
        global flagWin2
        flagWin2=False
        print('exitWin2')
        self.destroy()
    def ok(self):
        self.Retcode = "Print OK"
        self.exit2()
    def cancel(self):
        self.Retcode = None
        self.exit2()
class AppMain(tk.Tk):
    def __init__(self):
        super().__init__()
        global flagWin1,flagWin2
        flagWin1=flagWin2=False
        self.title(u'房贷记账小助手')
        self.geometry('240x480+10+480')
        self.resizable(False,False)
        self.wm_attributes('-topmost',True)
        self.code1 = 'T1234567'
        self.code2 = 123456789
        self.protocol("WM_DELETE_WINDOW", self.exitMainApp) #点击关闭按钮触发
        self.setup_UI()
    def setup_UI(self):
        tl1=tk.Label(self, text=u'凭证号:', width=8, anchor=tk.E)
        tl2=tk.Label(self, text=u'协议号:', width=8, anchor=tk.E)
        tl1.place(x=5,y=5)
        tl2.place(x=5,y=35)
        self.tl3 = tk.Label(self, text=self.code1, width=21, anchor=tk.W)
        self.tl4 = tk.Label(self, text=self.code2, width=21, anchor=tk.W)
        self.tl3.place(x=70,y=5)
        self.tl4.place(x=70,y=35)
        tb1=tk.Button(self, text=u"录入", command=self.setup_config)
        tb1.place(x=50,y=100)
        tb2=tk.Button(self, text=u"打印", command=self.setup_config2)
        tb2.place(x=120,y=100)
    def setup_config(self):
        global flagWin1,flagWin2
        if flagWin1:
            self.Input1.focus()
            return
        if flagWin2:
            self.Print1.focus()
            return
        res = self.get_voucherNum()
        if res is None: return
        self.code1, self.code2 = res
        self.tl3.config(text=self.code1)
        self.tl4.config(text=self.code2)
    def setup_config2(self):
        global flagWin1,flagWin2
        if flagWin1:
            self.Input1.focus()
            return
        if flagWin2:
            self.Print1.focus()
            return
        res = self.print_voucher()
        if res is None: return
    def get_voucherNum(self):
        '''对应Win1Input窗口类'''
        self.Input1 = Win1Input()
        self.wait_window(self.Input1)
        try:
            return self.Input1.Retcode
        except:
            pass
    def print_voucher(self):
        '''对应Win2Print窗口类'''
        print('print')
        self.Print1 = Win2Print()
        self.wait_window(self.Print1)
        try:
            return self.Print1.Retcode
        except:
            pass
    def exitMainApp(self):
        '''点击关闭按钮触发'''
        print(flagWin1,flagWin2) #退出时子窗口Win1,Win2是否打开
        if flagWin1 or flagWin2: return #判断子窗口是否关闭
        print('exit(0)')
        self.destroy()
if __name__ == '__main__':
    app = AppMain()
    app.mainloop()


运行效果截图:(实际运行时,两子窗口不能共存的)

20210414225037395.png




目录
相关文章
|
7月前
|
存储 人工智能 测试技术
如何使用LangChain的Python库结合DeepSeek进行多轮次对话?
本文介绍如何使用LangChain结合DeepSeek实现多轮对话,测开人员可借此自动生成测试用例,提升自动化测试效率。
1690 125
如何使用LangChain的Python库结合DeepSeek进行多轮次对话?
|
7月前
|
监控 数据可视化 数据挖掘
Python Rich库使用指南:打造更美观的命令行应用
Rich库是Python的终端美化利器,支持彩色文本、智能表格、动态进度条和语法高亮,大幅提升命令行应用的可视化效果与用户体验。
656 0
|
9月前
|
存储 Web App开发 前端开发
Python + Requests库爬取动态Ajax分页数据
Python + Requests库爬取动态Ajax分页数据
|
6月前
|
数据可视化 关系型数据库 MySQL
【可视化大屏】全流程讲解用python的pyecharts库实现拖拽可视化大屏的背后原理,简单粗暴!
本文详解基于Python的电影TOP250数据可视化大屏开发全流程,涵盖爬虫、数据存储、分析及可视化。使用requests+BeautifulSoup爬取数据,pandas存入MySQL,pyecharts实现柱状图、饼图、词云图、散点图等多种图表,并通过Page组件拖拽布局组合成大屏,支持多种主题切换,附完整源码与视频讲解。
626 4
【可视化大屏】全流程讲解用python的pyecharts库实现拖拽可视化大屏的背后原理,简单粗暴!
|
6月前
|
传感器 运维 前端开发
Python离群值检测实战:使用distfit库实现基于分布拟合的异常检测
本文解析异常(anomaly)与新颖性(novelty)检测的本质差异,结合distfit库演示基于概率密度拟合的单变量无监督异常检测方法,涵盖全局、上下文与集体离群值识别,助力构建高可解释性模型。
509 10
Python离群值检测实战:使用distfit库实现基于分布拟合的异常检测
|
8月前
|
运维 Linux 开发者
Linux系统中使用Python的ping3库进行网络连通性测试
以上步骤展示了如何利用 Python 的 `ping3` 库来检测网络连通性,并且提供了基本错误处理方法以确保程序能够优雅地处理各种意外情形。通过简洁明快、易读易懂、实操性强等特点使得该方法非常适合开发者或系统管理员快速集成至自动化工具链之内进行日常运维任务之需求满足。
559 18
|
8月前
|
机器学习/深度学习 API 异构计算
JAX快速上手:从NumPy到GPU加速的Python高性能计算库入门教程
JAX是Google开发的高性能数值计算库,旨在解决NumPy在现代计算需求下的局限性。它不仅兼容NumPy的API,还引入了自动微分、GPU/TPU加速和即时编译(JIT)等关键功能,显著提升了计算效率。JAX适用于机器学习、科学模拟等需要大规模计算和梯度优化的场景,为Python在高性能计算领域开辟了新路径。
788 0
JAX快速上手:从NumPy到GPU加速的Python高性能计算库入门教程
|
8月前
|
数据采集 存储 Web App开发
Python爬虫库性能与选型实战指南:从需求到落地的全链路解析
本文深入解析Python爬虫库的性能与选型策略,涵盖需求分析、技术评估与实战案例,助你构建高效稳定的数据采集系统。
629 0
|
8月前
|
存储 监控 安全
Python剪贴板监控实战:clipboard-monitor库的深度解析与扩展应用
本文介绍了基于Python的剪贴板监控技术,结合clipboard-monitor库实现高效、安全的数据追踪。内容涵盖技术选型、核心功能开发、性能优化及实战应用,适用于安全审计、自动化办公等场景,助力提升数据管理效率与安全性。
294 0

推荐镜像

更多
下一篇
开通oss服务