修改後的完整代碼

时间: 2023-08-07 07:17:35 浏览: 44
好的,以下是修改后的完整代码,你可以参考一下: ```python import os import datetime import tkinter as tk import openpyxl as xl class App: def __init__(self, master): self.master = master master.title("Excel Reader") # 初始化界面 self.init_ui() def init_ui(self): # 创建顶层框架 self.top_frame = tk.Frame(self.master) self.top_frame.pack(side="top", padx=10, pady=(10, 0)) # 创建标签和下拉菜单 self.label = tk.Label(self.top_frame, text="选择文件:") self.label.pack(side="left") self.file_var = tk.StringVar() self.file_menu = tk.OptionMenu(self.top_frame, self.file_var, "") self.file_menu.pack(side="left", padx=10) # 创建按钮 self.button = tk.Button(self.top_frame, text="打开", command=self.open_file) self.button.pack(side="left") # 创建中间框架 self.middle_frame = tk.Frame(self.master) self.middle_frame.pack(padx=10, pady=10) # 创建标签和列表框 self.selected_label = tk.Label(self.middle_frame, text="选择工作表:") self.selected_label.grid(row=0, column=0) self.sheet_frame = tk.Frame(self.middle_frame) self.sheet_frame.grid(row=1, column=0) self.unique_listbox = tk.Frame(self.middle_frame, relief="ridge", bd=2) self.unique_listbox.grid(row=1, column=1, padx=10) # 创建底部框架和标签 self.bottom_frame = tk.Frame(self.master) self.bottom_frame.pack(side="bottom", padx=10, pady=(0, 10)) self.status_label = tk.Label(self.bottom_frame, text="") self.status_label.pack() def open_file(self): # 打开文件对话框并获取选择的文件名 filename = tk.filedialog.askopenfilename(filetypes=[("Excel Files", "*.xlsx")]) if filename: # 保存文件名并更新下拉菜单 self.file_var.set(filename) self.update_file_menu() def update_file_menu(self): # 更新下拉菜单中的文件列表 filename = self.file_var.get() if filename: self.workbook = xl.load_workbook(filename) self.sheet_names = sorted(self.workbook.sheetnames) self.sheet_menu = tk.Menu(self.file_menu) for sheet_name in self.sheet_names: self.sheet_menu.add_command(label=sheet_name, command=lambda name=sheet_name: self.update_sheet_label(name)) self.file_menu['menu'] = self.sheet_menu # 清空左侧面板 for widget in self.sheet_frame.winfo_children(): widget.destroy() # 清空右下侧面板 for widget in self.unique_listbox.winfo_children(): widget.destroy() # 在左侧添加标签 self.sheet_label = tk.Label(self.sheet_frame, text="") self.sheet_label.pack() # 在右下侧添加标签 for i, sheet_name in enumerate(self.sheet_names): label = tk.Label(self.unique_listbox, text=sheet_name) label.grid(row=i // 5, column=i % 5, sticky="ew", padx=1, pady=1) def update_sheet_label(self, sheet_name): # 更新左侧标签文本 self.sheet_label.config(text=sheet_name) # 清空右下侧面板 for widget in self.unique_listbox.winfo_children(): widget.destroy() # 获取所选标签文本 selected_label_text = self.selected_label.cget("text") if selected_label_text: # 读取第3列日期和第9列文本内容 for i, sheet_name in enumerate(self.sheet_names): sheet = self.workbook[sheet_name] for row in sheet.iter_rows(min_row=2, values_only=True): date = row[2] # 第3列为日期列 text = row[8] # 第9列为文本内容列 if isinstance(date, datetime.date) and date == datetime.date.today() and text == selected_label_text: # 如果日期为今天并且文本内容与所选标签文本相同,则在标签后面添加已点检 label = tk.Label(self.unique_listbox, text=f"{sheet_name} 已点检") label.grid(row=i // 5, column=i % 5, sticky="ew", padx=1, pady=1) break else: # 如果当前工作表中没有符合条件的行,则在标签后面添加未点检 label = tk.Label(self.unique_listbox, text=f"{sheet_name} 未点检") label.grid(row=i // 5, column=i % 5, sticky="ew", padx=1, pady=1) else: # 如果没有选择标签,则在标签后面添加未点检 for i, sheet_name in enumerate(self.sheet_names): label = tk.Label(self.unique_listbox, text=f"{sheet_name} 未点检") label.grid(row=i // 5, column=i % 5, sticky="ew", padx=1, pady=1) # 创建主窗口并运行程序 if __name__ == '__main__': root = tk.Tk() app = App(root) root.mainloop() ``` 代码中主要修改的部分就是在 `update_sheet_label` 函数中添加的读取第3列日期和第9列文本内容的代码,以及在遍历每个工作表中的行时,如果找到符合条件的行,则在标签后面添加“已点检”文本,否则添加“未点检”文本。

相关推荐

最新推荐

recommend-type

git log根据特定条件查询日志并统计修改的代码行数

本篇文章将深入探讨如何使用`git log`根据特定条件查询日志,并统计修改的代码行数。 首先,了解`git log`的基本用法。它默认会列出所有提交,每条提交包括作者、时间戳、提交信息等。例如,你可以使用`git log`...
recommend-type

简单快速修改 Mastercam后处理

* Mastercam的后处理文件可以使用Notepad++或MC自带的代码编辑器来修改。 后处理修改的常见问题 * 如何去掉行号等设置方法? * 如何删除“(T)”注释? * 如何将T1 M6换成M6 T1? 答案 * 使用post debugger可以...
recommend-type

Pandas读取并修改excel的示例代码

完成修改后,记得再次调用`to_excel()`保存更改。 通过这些基本操作,Pandas使得Python与Excel文件之间的交互变得简单而高效,无论是在数据清洗、分析还是建模过程中,Pandas都是处理Excel数据的强大助手。在实际...
recommend-type

linux中批量修改文件名的脚本代码

linux中批量修改文件名的脚本代码,主要是使用了rename,结合shell,喜欢的朋友可以参考下
recommend-type

如何使用Cython对python代码进行加密

在Python编程中,有时为了保护代码不被轻易查看或修改,开发者会选择对代码进行加密。Cython是一种能够将Python代码转换为C语言的工具,进而编译成二进制形式,实现对Python源码的加密。本文将详细介绍如何使用...
recommend-type

计算机基础知识试题与解答

"计算机基础知识试题及答案-(1).doc" 这篇文档包含了计算机基础知识的多项选择题,涵盖了计算机历史、操作系统、计算机分类、电子器件、计算机系统组成、软件类型、计算机语言、运算速度度量单位、数据存储单位、进制转换以及输入/输出设备等多个方面。 1. 世界上第一台电子数字计算机名为ENIAC(电子数字积分计算器),这是计算机发展史上的一个重要里程碑。 2. 操作系统的作用是控制和管理系统资源的使用,它负责管理计算机硬件和软件资源,提供用户界面,使用户能够高效地使用计算机。 3. 个人计算机(PC)属于微型计算机类别,适合个人使用,具有较高的性价比和灵活性。 4. 当前制造计算机普遍采用的电子器件是超大规模集成电路(VLSI),这使得计算机的处理能力和集成度大大提高。 5. 完整的计算机系统由硬件系统和软件系统两部分组成,硬件包括计算机硬件设备,软件则包括系统软件和应用软件。 6. 计算机软件不仅指计算机程序,还包括相关的文档、数据和程序设计语言。 7. 软件系统通常分为系统软件和应用软件,系统软件如操作系统,应用软件则是用户用于特定任务的软件。 8. 机器语言是计算机可以直接执行的语言,不需要编译,因为它直接对应于硬件指令集。 9. 微机的性能主要由CPU决定,CPU的性能指标包括时钟频率、架构、核心数量等。 10. 运算器是计算机中的一个重要组成部分,主要负责进行算术和逻辑运算。 11. MIPS(Millions of Instructions Per Second)是衡量计算机每秒执行指令数的单位,用于描述计算机的运算速度。 12. 计算机存储数据的最小单位是位(比特,bit),是二进制的基本单位。 13. 一个字节由8个二进制位组成,是计算机中表示基本信息的最小单位。 14. 1MB(兆字节)等于1,048,576字节,这是常见的内存和存储容量单位。 15. 八进制数的范围是0-7,因此317是一个可能的八进制数。 16. 与十进制36.875等值的二进制数是100100.111,其中整数部分36转换为二进制为100100,小数部分0.875转换为二进制为0.111。 17. 逻辑运算中,0+1应该等于1,但选项C错误地给出了0+1=0。 18. 磁盘是一种外存储设备,用于长期存储大量数据,既可读也可写。 这些题目旨在帮助学习者巩固和检验计算机基础知识的理解,涵盖的领域广泛,对于初学者或需要复习基础知识的人来说很有价值。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

【进阶】音频处理基础:使用Librosa

![【进阶】音频处理基础:使用Librosa](https://picx.zhimg.com/80/v2-a39e5c9bff1d920097341591ca8a2dfe_1440w.webp?source=1def8aca) # 2.1 Librosa库的安装和导入 Librosa库是一个用于音频处理的Python库。要安装Librosa库,请在命令行中输入以下命令: ``` pip install librosa ``` 安装完成后,可以通过以下方式导入Librosa库: ```python import librosa ``` 导入Librosa库后,就可以使用其提供的各种函数
recommend-type

设置ansible 开机自启

Ansible是一个强大的自动化运维工具,它可以用来配置和管理服务器。如果你想要在服务器启动时自动运行Ansible任务,通常会涉及到配置服务或守护进程。以下是使用Ansible设置开机自启的基本步骤: 1. **在主机上安装必要的软件**: 首先确保目标服务器上已经安装了Ansible和SSH(因为Ansible通常是通过SSH执行操作的)。如果需要,可以通过包管理器如apt、yum或zypper安装它们。 2. **编写Ansible playbook**: 创建一个YAML格式的playbook,其中包含`service`模块来管理服务。例如,你可以创建一个名为`setu
recommend-type

计算机基础知识试题与解析

"计算机基础知识试题及答案(二).doc" 这篇文档包含了计算机基础知识的多项选择题,涵盖了操作系统、硬件、数据表示、存储器、程序、病毒、计算机分类、语言等多个方面的知识。 1. 计算机系统由硬件系统和软件系统两部分组成,选项C正确。硬件包括计算机及其外部设备,而软件包括系统软件和应用软件。 2. 十六进制1000转换为十进制是4096,因此选项A正确。十六进制的1000相当于1*16^3 = 4096。 3. ENTER键是回车换行键,用于确认输入或换行,选项B正确。 4. DRAM(Dynamic Random Access Memory)是动态随机存取存储器,选项B正确,它需要周期性刷新来保持数据。 5. Bit是二进制位的简称,是计算机中数据的最小单位,选项A正确。 6. 汉字国标码GB2312-80规定每个汉字用两个字节表示,选项B正确。 7. 微机系统的开机顺序通常是先打开外部设备(如显示器、打印机等),再开启主机,选项D正确。 8. 使用高级语言编写的程序称为源程序,需要经过编译或解释才能执行,选项A正确。 9. 微机病毒是指人为设计的、具有破坏性的小程序,通常通过网络传播,选项D正确。 10. 运算器、控制器及内存的总称是CPU(Central Processing Unit),选项A正确。 11. U盘作为外存储器,断电后存储的信息不会丢失,选项A正确。 12. 财务管理软件属于应用软件,是为特定应用而开发的,选项D正确。 13. 计算机网络的最大好处是实现资源共享,选项C正确。 14. 个人计算机属于微机,选项D正确。 15. 微机唯一能直接识别和处理的语言是机器语言,它是计算机硬件可以直接执行的指令集,选项D正确。 16. 断电会丢失原存信息的存储器是半导体RAM(Random Access Memory),选项A正确。 17. 硬盘连同驱动器是一种外存储器,用于长期存储大量数据,选项B正确。 18. 在内存中,每个基本单位的唯一序号称为地址,选项B正确。 以上是对文档部分内容的详细解释,这些知识对于理解和操作计算机系统至关重要。