def load_excel(self, filename,menu_label): self.la=menu_label self.workbook = xl.load_workbook(filename) self.sheet_names = self.workbook.sheetnames # 清空左侧面板 for widget in self.panel_left.winfo_children(): widget.destroy() # 添加工作表按钮 style = ttk.Style() style.configure('my.TButton', font=('Arial', 10)) style.map('my.TButton', background=[('active', '#007FFF')]) for i, sheet_name in enumerate(self.sheet_names): button = ttk.Button(self.panel_left, text=sheet_name, command=lambda name=sheet_name: self.show_sheet(name), style='my.TButton') button.used = False button.grid(row=i, column=0, sticky="ew", padx=2, pady=2) button.bind("<Enter>", lambda event, button=button: button.config(relief="sunken")) button.bind("<Leave>", lambda event, button=button: button.config(relief="raised")) button.bind("<Button-1>", lambda event, button=button: mark_used(button)) def mark_used(button): # 将按钮的标记设置为“已使用” button.used = True # 更改按钮的背景颜色 button.configure(bg="gray") # 更新界面 button.update() for child in self.panel_left.winfo_children(): # 绑定按钮的点击事件 child.bind("<Button-1>", lambda event, button=child: mark_used(button)修改這段代碼儅用戶點擊生成的工作表按鈕后相應按鈕變爲綠色
时间: 2023-12-02 21:03:55 浏览: 44
你可以在 `mark_used()` 函数中添加代码来将按钮的背景颜色更改为绿色。修改后的代码如下:
```
def mark_used(button):
# 将按钮的标记设置为“已使用”
button.used = True
# 更改按钮的背景颜色为绿色
button.configure(bg="green")
# 更新界面
button.update()
```
这样,当用户单击工作表按钮时,相应的按钮将变为绿色。记得将这段代码添加到原来的代码中相应的位置。
相关问题
def load_excel(self, filename, menu_label, selected_label_text): for widget in self.sheet_frame.winfo_children(): widget.destroy() for widget in self.unique_listbox.winfo_children(): widget.destroy() self.la = menu_label self.workbook = xl.load_workbook(filename) self.sheet_names = sorted(self.workbook.sheetnames) self.selected_label.config(text=selected_label_text)給這段代碼后面添加注解
这段代码定义了一个名为 "load_excel" 的方法,它接受三个参数:文件名、菜单标签和选定标签的文本。这个方法的作用是加载 Excel 文件,并将 Excel 文件中的数据显示在界面上。
首先,代码使用 "winfo_children()" 方法清空了 "sheet_frame" 和 "unique_listbox" 中的所有子部件。然后,代码设置了 "la" 属性为 "menu_label" 参数,"workbook" 属性为使用 "xl.load_workbook()" 方法加载的 Excel 文件,"sheet_names" 属性为工作簿中所有工作表的名称列表。
最后,代码将 "selected_label" 的文本属性设置为 "selected_label_text" 参数。
该方法没有返回值,但它对界面进行了更新。
def load_excel(self, filename, menu_label, selected_label_text): self.la = menu_label self.workbook = xl.load_workbook(filename) self.sheet_names = sorted(self.workbook.sheetnames) # 按工作表名称从小到大排序 self.selected_label.config(text=selected_label_text) # 更新选中标签文本 # 清空左侧面板 for widget in self.sheet_frame.winfo_children(): widget.destroy() # 添加工作表按钮 for i, sheet_name in enumerate(self.sheet_names): button = tk.Button(self.sheet_frame, text=sheet_name, command=lambda name=sheet_name: self.show_sheet(name)) button.grid(row=i, column=0, sticky="ew", padx=1, pady=1)根據這個代碼在添加一個將讀取的excel工作表的表名生成文字標簽,就只是一個文字標簽顯示到這個列表框中# 创建标签和列表框 unique_label = tk.Label(text_frame, text="唯一值:") unique_label.pack(side=tk.LEFT, padx=5) self.unique_listbox = tk.Listbox(unique_frame) self.unique_listbox.pack(side=tk.LEFT, fill=tk.BOTH, expand=True)橫著放每五個一行
您的问题是如何将读取的Excel工作表的表名生成文字标签,并且将其显示到列表框中横着放每五个一行?
您可以在添加工作表按钮的循环中添加以下代码来生成并显示文字标签:
```
# 添加工作表标签
label = tk.Label(self.sheet_frame, text=sheet_name)
label.grid(row=i, column=1, sticky="w", padx=5, pady=1)
```
其中,`text`参数为表名,`row`和`column`参数分别为标签在网格布局中的行数和列数,`sticky`参数表示对齐方式,`padx`和`pady`参数表示标签边缘与网格单元格边缘之间的距离。
而横着放每五个一行,您可以在添加工作表按钮的循环中添加以下代码:
```
if i % 5 == 0:
self.sheet_frame.grid_columnconfigure(i//5, weight=1)
self.sheet_frame.grid(row=i//5, column=i%5, sticky="nsew", padx=1, pady=1)
```
其中,`grid_columnconfigure`方法用于设置网格布局中的列权重,使得每五个按钮为一行,`i//5`和`i%5`分别表示按钮所在的行数和列数,`sticky`参数表示对齐方式,`padx`和`pady`参数表示按钮边缘与网格单元格边缘之间的距离。
阅读全文