for i, sheet_name in enumerate(self.sheet_names): button = tk.Button(self.unique_listbox, text=sheet_name, command=lambda name=sheet_name: self.show_sheet(name)) button.grid(row=i, column=0, sticky="ew", padx=1, pady=1)將這段代碼修改為文本標簽,橫著放,5個一行
时间: 2023-12-07 21:03:18 浏览: 63
你可以尝试以下代码实现你想要的效果:
```
for i, sheet_name in enumerate(self.sheet_names):
label = tk.Label(self.unique_listbox, text=sheet_name)
label.grid(row=i//5, column=i%5, sticky="ew", padx=1, pady=1)
```
这里使用了整除和取模运算符,将标签放置在合适的行和列上,并且每行最多显示5个标签。你可以根据实际需要调整列数和padding值。
相关问题
def load_excel(self): try: # 读取excel文件 df = pd.read_excel(self.file_name, sheet_name=None) self.sheet_names = list(df.keys()) # 创建按键并添加到窗口中 for i, sheet_name in enumerate(self.sheet_names): button = ttk.Button(self, text=sheet_name, command=lambda sheet_name=sheet_name: self.show_data(sheet_name)) button.pack(side=tk.RIGHT, pady=10, anchor=tk.N) self.buttons.append(button) except Exception as e: self.log_text.insert(tk.END, str(e) + "\n")修改按鈕放到左邊竪著放
要将按键放到左边垂直排列,可以使用 `pack(side=tk.LEFT, padx=10)` 代替 `pack(side=tk.RIGHT, pady=10, anchor=tk.N)`,并将 `side` 参数设置为 `tk.LEFT`,`padx` 参数设置为适当的值以控制按键之间的间距。下面是修改后的代码:
```
def load_excel(self):
try:
# 读取excel文件
df = pd.read_excel(self.file_name, sheet_name=None)
self.sheet_names = list(df.keys())
# 创建按键并添加到窗口中
for i, sheet_name in enumerate(self.sheet_names):
button = ttk.Button(self, text=sheet_name,
command=lambda sheet_name=sheet_name: self.show_data(sheet_name))
button.pack(side=tk.LEFT, padx=10)
self.buttons.append(button)
except Exception as e:
self.log_text.insert(tk.END, str(e) + "\n")
```
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`参数表示按钮边缘与网格单元格边缘之间的距离。
阅读全文
相关推荐
![zip](https://img-home.csdnimg.cn/images/20241231045053.png)
![zip](https://img-home.csdnimg.cn/images/20241231045053.png)
![zip](https://img-home.csdnimg.cn/images/20241231045053.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![pdf](https://img-home.csdnimg.cn/images/20241231044930.png)
![pptx](https://img-home.csdnimg.cn/images/20241231044947.png)
![zip](https://img-home.csdnimg.cn/images/20241231045053.png)
![pdf](https://img-home.csdnimg.cn/images/20241231044930.png)