class ExcelApp: def init(self, master): self.master = master master.title("Excel App") # 创建菜单栏 menubar = tk.Menu(master) master.config(menu=menubar) # 创建文件菜单及其子菜单 filemenu = tk.Menu(menubar, tearoff=0) filemenu.add_command(label="PA綫點檢表", command=lambda: self.load_excel("D:\點檢系統存放資料夾\點檢明細\點檢内容明細.xlsx")) filemenu.add_command(label="Excel 2", command=lambda: self.load_excel("excel2.xlsx")) filemenu.add_command(label="Excel 3", command=lambda: self.load_excel("excel3.xlsx")) menubar.add_cascade(label="文件", menu=filemenu) # 创建帮助菜单及其子菜单 helpmenu = tk.Menu(menubar, tearoff=0) helpmenu.add_command(label="关于", command=self.show_about) menubar.add_cascade(label="帮助", menu=helpmenu) # 创建工具栏 toolbar = tk.Frame(master, height=30) tk.Button(toolbar, text="打开", command=self.open_file).pack(side=tk.LEFT, padx=2, pady=2) tk.Button(toolbar, text="保存", command=self.save_to_excel).pack(side=tk.LEFT, padx=2, pady=2) toolbar.pack(side=tk.TOP, fill=tk.X) # 创建左侧面板 self.panel_left = tk.Frame(master, width=150, bg='lightcyan') self.panel_left.pack(side=tk.LEFT, fill=tk.Y) # 创建右侧面板 self.panel_right = tk.Frame(master) self.panel_right.pack(side=tk.LEFT, fill=tk.BOTH, expand=True) # 创建Frame来包含标签和下拉框 input_frame = tk.Frame(self.panel_right) input_frame.pack(side=tk.TOP, fill=tk.X, padx=5, pady=5) # 创建标签和下拉框 ri = datetime.datetime.now().strftime('%Y/%m/%d') ri1 = datetime.datetime.now().strftime('%H:%M:%S') self.label1 = tk.Label(input_frame, text="點檢日期") self.label1.pack(side=tk.LEFT, padx=2, pady=2) self.combobox1 = tk.ttk.Combobox(input_frame, values=[ri]) self.combobox1.pack(side=tk.LEFT, padx=2, pady=2) self.combobox1.current(0) self.label2 = tk.Label(input_frame, text="點檢時間") self.label2.pack(side=tk.LEFT, padx=2, pady=2) self.combobox2 = tk.ttk.Combobox(input_frame, values=[ri1]) self.combobox2.pack(side=tk.LEFT, padx=2, pady=2) self.combobox2.current(0)在這段代碼中需要在self.combobox2輸入實時跟新的時間
时间: 2024-02-05 21:11:14 浏览: 81
你可以使用 `after()` 方法来实现定时更新时间,例如每秒更新一次。具体实现方法如下:
1. 定义一个方法 `update_time`,用于更新时间和更新 Combobox 中的值。
```python
def update_time(self):
now = datetime.datetime.now()
date_str = now.strftime('%Y/%m/%d')
time_str = now.strftime('%H:%M:%S')
self.combobox1.configure(values=[date_str])
self.combobox1.current(0)
self.combobox2.configure(values=[time_str])
self.combobox2.current(0)
self.master.after(1000, self.update_time) # 每秒更新一次
```
2. 在 `__init__()` 方法中,调用 `update_time` 方法,启动时间更新。
```python
def __init__(self, master):
# ...
self.update_time() # 启动时间更新
```
注意,这里使用了 `self.master.after(1000, self.update_time)` 来实现定时更新。其中,`self.master` 是主窗口对象,`after()` 方法的第一个参数表示等待的时间(毫秒),第二个参数是要执行的方法。因此,上述代码表示每隔 1000 毫秒(即 1 秒),调用一次 `update_time` 方法,实现时间的更新。
阅读全文