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)橫著放每五個一行
时间: 2023-12-29 12:05:06 浏览: 77
Read data from the Excel spreadsheet.zip_Spreadsheet::Read_excel
您的问题是如何将读取的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`参数表示按钮边缘与网格单元格边缘之间的距离。
阅读全文