class MainWindow: def __init__(self, master): self.option_list = [] self.master = master master.title("點檢系統") # 获取屏幕的宽度和高度 screen_width = master.winfo_screenwidth() screen_height = master.winfo_screenheight() # 将窗口的大小设置为屏幕的大小 master.geometry("%dx%d" % (screen_width, screen_height))# 创建菜单栏 menu_bar = tk.Menu(master) # 创建“文件”菜单 file_menu = tk.Menu(menu_bar, tearoff=0) file_menu.add_command(label="5M點檢表", command=lambda: self.read_from_excel(file_menu, "5M點檢表")) file_menu.add_command(label="Router首件检查记录表", command=lambda: self.read_from_excel1(file_menu, "Router首件检查记录表")) file_menu.add_command(label="板组作业首件检查记录表", command=lambda: self.read_from_excel2(file_menu, "板组作业首件检查记录表")) # 创建“保养”菜单 maintenance_menu = tk.Menu(menu_bar, tearoff=0) maintenance_menu.add_command(label="日保養", command=lambda: self.read_from_excel3(maintenance_menu, "日保養")) maintenance_menu.add_command(label="周保養", command=lambda: self.read_from_excel4(maintenance_menu, "周保養")) # 创建“测试”菜单 test_menu = tk.Menu(menu_bar, tearoff=0) test_menu.add_command(label="人工測試站表單", command=lambda: self.read_from_excel5(test_menu, "人工測試站表單")) test_menu.add_command(label="自動化測試站表單", command=lambda: self.read_from_excel6(test_menu, "自動化測試站表單")) # 将子菜单添加到菜单栏 menu_bar.add_cascade(label="首件確認表單", menu=file_menu) menu_bar.add_cascade(label="保养表單", menu=maintenance_menu) menu_bar.add_cascade(label="F/T表單", menu=test_menu) # 将菜单栏添加到主窗口 master.config(menu=menu_bar)在這個代碼中需要獲取用戶點擊的菜單欄中子菜單的名稱寫入excel中
时间: 2023-11-22 11:53:12 浏览: 95
可以使用openpyxl库来实现将用户点击的菜单栏子菜单的名称写入Excel中。
首先在类的初始化方法中创建一个Excel工作簿对象:
```
import openpyxl
class MainWindow:
def __init__(self, master):
self.workbook = openpyxl.Workbook()
# ...
```
然后在每个菜单栏子菜单的回调函数中,获取子菜单的名称并将其写入Excel中。下面以读取“5M點檢表”子菜单为例:
```
class MainWindow:
def read_from_excel(self, menu, name):
# 获取子菜单的名称
submenu_name = menu.entrycget(name, "label")
# 将子菜单名称写入Excel
sheet = self.workbook.active
sheet.cell(row=1, column=1, value=submenu_name)
```
以上代码将获取到的子菜单名称写入Excel的A1单元格中。可以根据需要修改行号和列号。
最后,记得在程序退出时保存Excel文件:
```
class MainWindow:
def __init__(self, master):
# ...
master.protocol("WM_DELETE_WINDOW", self.on_exit)
def on_exit(self):
self.workbook.save("菜单栏子菜单.xlsx")
self.master.destroy()
```
阅读全文