python寫一個gui窗口,這個界面有菜單欄,菜單有子菜單,每個子菜單連接一個指定的excel表,在窗口上方添加一個工具欄位,顯示上傳和關閉按鈕,儅用戶選擇任意一個子菜單時將相應讀取excel中所有工作表並生成按鈕顯示在窗口左側竪著排列為防止應工作表過多需要添加滑動條來顯示數據,在右右側創建一個文本框,儅用戶點擊生成的按鈕時,這個文本框就讀取相應excel工作表數據的一列所有數據并在每行數據前面添加一個下拉輸入框,顯示在文本框中,一樣需要滾動條來滾動數據

时间: 2023-12-06 20:05:44 浏览: 26
好的,以下是一个实现你要求的 Python GUI 窗口的示例代码: ```python import tkinter as tk import tkinter.filedialog as fd import openpyxl class ExcelReader: def __init__(self): self.workbook = None def open_excel(self, file_path): self.workbook = openpyxl.load_workbook(file_path) def get_worksheets(self): return self.workbook.sheetnames def get_row_data(self, worksheet_name): worksheet = self.workbook[worksheet_name] rows = [] for row in worksheet.iter_rows(min_row=1, values_only=True): rows.append(row) return rows class App: def __init__(self, master): self.master = master self.master.title("Excel Reader") self.excel_reader = ExcelReader() # 创建菜单栏 menu_bar = tk.Menu(self.master) # 创建文件菜单 file_menu = tk.Menu(menu_bar, tearoff=0) file_menu.add_command(label="打开", command=self.open_file) file_menu.add_command(label="退出", command=self.quit_app) menu_bar.add_cascade(label="文件", menu=file_menu) # 创建工具栏 toolbar = tk.Frame(self.master, bd=1, relief=tk.RAISED) upload_button = tk.Button(toolbar, text="上传", command=self.open_file) upload_button.pack(side=tk.LEFT, padx=2, pady=2) close_button = tk.Button(toolbar, text="关闭", command=self.quit_app) close_button.pack(side=tk.LEFT, padx=2, pady=2) toolbar.pack(side=tk.TOP, fill=tk.X) # 创建滚动区域 scroll_area = tk.Frame(self.master) self.buttons_frame = tk.Frame(scroll_area) scroll_bar = tk.Scrollbar(scroll_area, orient=tk.VERTICAL) scroll_bar.pack(side=tk.RIGHT, fill=tk.Y) scroll_bar.config(command=self.buttons_frame.yview) self.buttons_frame.config(yscrollcommand=scroll_bar.set) self.buttons_frame.pack(side=tk.LEFT, fill=tk.BOTH, expand=True) scroll_area.pack(side=tk.LEFT, fill=tk.BOTH, expand=True) # 创建文本框 self.text_box = tk.Text(self.master) self.text_box.pack(side=tk.RIGHT, fill=tk.BOTH, expand=True) # 初始化窗口 self.master.config(menu=menu_bar, width=800, height=600) def open_file(self): file_path = fd.askopenfilename() if file_path: self.excel_reader.open_excel(file_path) self.generate_worksheet_buttons() def quit_app(self): self.master.quit() def generate_worksheet_buttons(self): # 删除已有按钮 for child in self.buttons_frame.winfo_children(): child.destroy() # 生成新按钮 worksheets = self.excel_reader.get_worksheets() for worksheet_name in worksheets: button = tk.Button(self.buttons_frame, text=worksheet_name, command=lambda name=worksheet_name: self.show_worksheet_data(name)) button.pack(side=tk.TOP, fill=tk.X) def show_worksheet_data(self, worksheet_name): rows = self.excel_reader.get_row_data(worksheet_name) self.text_box.delete(1.0, tk.END) for row in rows: dropdown = tk.OptionMenu(self.text_box, tk.StringVar(value=row[0]), *row) self.text_box.window_create(tk.INSERT, window=dropdown) self.text_box.insert(tk.INSERT, "\n") if __name__ == "__main__": root = tk.Tk() app = App(root) root.mainloop() ``` 这个窗口有菜单栏和工具栏,菜单栏包含文件菜单,工具栏包含上传和关闭按钮。当用户点击文件菜单中的“打开”命令时,会打开一个文件对话框,让用户选择要读取的 Excel 文件。选择文件后,程序会读取文件中的所有工作表,并在窗口左侧生成一个按钮列表,每个按钮与一个工作表对应。当用户点击这些按钮中的任意一个时,程序会读取相应的工作表数据,并在窗口右侧的文本框中显示,每个数据行都有一个下拉框选项。如果工作表数据比较多,用户可以使用文本框左侧的滚动条来滚动数据。如果窗口太小,用户还可以调整窗口大小。

相关推荐

zip
VR(Virtual Reality)即虚拟现实,是一种可以创建和体验虚拟世界的计算机技术。它利用计算机生成一种模拟环境,是一种多源信息融合的、交互式的三维动态视景和实体行为的系统仿真,使用户沉浸到该环境中。VR技术通过模拟人的视觉、听觉、触觉等感觉器官功能,使人能够沉浸在计算机生成的虚拟境界中,并能够通过语言、手势等自然的方式与之进行实时交互,创建了一种适人化的多维信息空间。 VR技术具有以下主要特点: 沉浸感:用户感到作为主角存在于模拟环境中的真实程度。理想的模拟环境应该使用户难以分辨真假,使用户全身心地投入到计算机创建的三维虚拟环境中,该环境中的一切看上去是真的,听上去是真的,动起来是真的,甚至闻起来、尝起来等一切感觉都是真的,如同在现实世界中的感觉一样。 交互性:用户对模拟环境内物体的可操作程度和从环境得到反馈的自然程度(包括实时性)。例如,用户可以用手去直接抓取模拟环境中虚拟的物体,这时手有握着东西的感觉,并可以感觉物体的重量,视野中被抓的物体也能立刻随着手的移动而移动。 构想性:也称想象性,指用户沉浸在多维信息空间中,依靠自己的感知和认知能力获取知识,发挥主观能动性,寻求解答,形成新的概念。此概念不仅是指观念上或语言上的创意,而且可以是指对某些客观存在事物的创造性设想和安排。 VR技术可以应用于各个领域,如游戏、娱乐、教育、医疗、军事、房地产、工业仿真等。随着VR技术的不断发展,它正在改变人们的生活和工作方式,为人们带来全新的体验。

最新推荐

recommend-type

python GUI库图形界面开发之PyQt5菜单栏控件QMenuBar的详细使用方法与实例

级联的QMenu对象,要创建一个弹出菜单,Pyqt提供了createPopupMenu()函数,menuBar()函数用于返回主窗口的QMenuBar对象:addMenu()函数可以将菜单添加到菜单栏中,通过addAction()函数可以在菜单中进行添加...
recommend-type

Python实现保证只能运行一个脚本实例

主要介绍了Python实现保证只能运行一个脚本实例,本文直接给出实现代码,需要的朋友可以参考下
recommend-type

python分割一个文本为多个文本的方法

主要为大家详细介绍了python分割一个文本为多个文本,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

Python实现调用另一个路径下py文件中的函数方法总结

主要介绍了Python实现调用另一个路径下py文件中的函数方法,结合实例形式总结分析了Python针对不同文件夹中py文件调用操作的处理技巧与相关注意事项,需要的朋友可以参考下
recommend-type

python字符串替换第一个字符串的方法

主要介绍了python字符串替换第一个字符串的方法,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

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

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

list根据id查询pid 然后依次获取到所有的子节点数据

可以使用递归的方式来实现根据id查询pid并获取所有子节点数据。具体实现可以参考以下代码: ``` def get_children_nodes(nodes, parent_id): children = [] for node in nodes: if node['pid'] == parent_id: node['children'] = get_children_nodes(nodes, node['id']) children.append(node) return children # 测试数
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。