def load_excel(self, filename): self.workbook = xl.load_workbook(filename) self.sheet_names = self.workbook.sheetnames # 清空左侧面板 for widget in self.panel_left.winfo_children(): widget.destroy() # 添加工作表按钮 for sheet_name in self.sheet_names: button = tk.Button(self.panel_left, text=sheet_name, command=lambda name=sheet_name: self.show_sheet(name)) button.pack(side=tk.TOP, fill=tk.X, padx=5, pady=5)在這段代碼中添加儅用戶點擊生成的按鈕時按鈕可以更改 顔色
时间: 2023-12-23 12:06:01 浏览: 39
你可以在创建按钮的时候,通过设置 `bg` 参数来改变按钮的背景颜色,比如:
```
button = tk.Button(self.panel_left, text=sheet_name, command=lambda name=sheet_name: self.show_sheet(name), bg="red")
```
这样创建的按钮的背景颜色就是红色的,你可以根据自己的需要设置其他颜色。
相关问题
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)在這個代碼中添加一個將生成的按鈕在寫入這個面板中# 创建Frame来放置唯一值面板 unique_frame = tk.Frame(self.panel_right, bg='white') unique_frame.pack(side=tk.TOP, fill=tk.X, padx=5, pady=5),放置方式改爲橫著每5個一行,按鈕改爲文本,不帶其他功能
可以在添加工作表按钮的循环中,加入以下代码来实现按照行数5个一行,文本按钮的功能:
```
# 添加工作表按钮
for i, sheet_name in enumerate(self.sheet_names):
button = tk.Button(self.sheet_frame, text=sheet_name)
button.grid(row=i%5, column=i//5, sticky="ew", padx=1, pady=1)
```
这里使用了取模(%)和整除(//)操作来确定按钮的行和列。同时,每个按钮的 padx 和 pady 值可以根据需要进行调整。
阅读全文