# 创建表格用于显示第一个工作表 columns1 = next(self.record_sheet.iter_rows(min_row=1, max_row=1, values_only=True)) treeview1 = ttk.Treeview(self.container1, columns=columns1, show="headings", style="MyTreeview1.Treeview") treeview1.grid(row=1, column=3, rowspan=1, padx=5, pady=5, sticky="nsew") treeview1.config(height=10) treeview1.config(width=8) # 设置表格列的标题和宽度 for col in columns1: treeview1.heading(col, text=col) treeview1.column(col, width=100, anchor="center") # 显示第一个工作表的内容 for row in self.record_sheet.iter_rows(min_row=2, values_only=True): row_values = [str(cell) if cell is not None else "" for cell in row] if all(not bool(cell) for cell in row_values): continue treeview1.insert("", tk.END, values=row_values)_tkinter.TclError: unknown option "-width"
时间: 2024-03-19 17:42:49 浏览: 65
这个错误是因为你在 `treeview1.column()` 方法中使用了未知的选项 `width`。实际上,`treeview1.column()` 方法只支持 `minwidth` 和 `stretch` 选项。如果你想设置列的宽度,可以使用 `minwidth` 选项。例如,你可以使用 `treeview1.column(col, minwidth=100, anchor="center")` 来设置列的最小宽度为 100。注意,这里的选项名是 `minwidth`,而不是 `width`。
相关问题
显示excel内容的回调函数 def show_excel(self): # 创建表格用于显示第一个工作表 columns1 = next(self.record_sheet.iter_rows(min_row=1, max_row=1, values_only=True)) treeview1 = ttk.Treeview(self.container1, columns=columns1, show="headings") treeview1.grid(row=1, column=3, rowspan=1, padx=5, pady=5, sticky="nsew") # 设置表格列的标题和宽度 for col in columns1: treeview1.heading(col, text=col) treeview1.column(col, width=100, anchor="center") # 显示第一个工作表的内容 for row in self.record_sheet.iter_rows(min_row=2, values_only=True): row_values = [cell if cell is not None else "" for cell in row] if all(not bool(cell) for cell in row_values): continue treeview1.insert("", tk.END, values=row_values) # 创建表格用于显示第二个工作表 columns2 = next(self.data_sheet.iter_rows(min_row=1, max_row=1, values_only=True)) treeview2 = ttk.Treeview(self.container1, columns=columns2, show="headings") treeview2.grid(row=3, column=3, padx=5, pady=5, sticky="nsew") # 设置表格列的标题和宽度 for col in columns2: treeview2.heading(col, text=col) treeview2.column(col, width=100, anchor="center") # 显示第二个工作表的内容 for row in self.data_sheet.iter_rows(min_row=2, values_only=True): row_values = [cell if cell is not None else "" for cell in row] if all(not bool(cell) for cell in row_values): continue treeview2.insert("", tk.END, values=row_values) # 设置文本框大小一致 self.material_name1.config(width=20) self.material_qty.config(width=20)這些表格中的數據需要用所有綫框框起來
要让这些表格中的数据周围使用所有的线框进行框起来,可以在`show_excel`函数中,在两个表格中关于创建和配置`TreeView`的代码前后添加以下代码:
```
style = ttk.Style()
style.configure("Treeview", rowheight=25, borderwidth=1, relief="solid", font=('Arial', 10))
style.configure("Treeview.Heading", font=('Arial', 10, 'bold'))
style.layout("Treeview", [('Treeview.treearea', {'sticky': 'nswe'})])
```
这样,就可以将表格中的数据周围使用所有的线框进行框起来。其中,`borderwidth`和`relief`参数用于设置边框的宽度和样式。在这里,`borderwidth`被设置为1,`relief`被设置为`solid`,表示边框是实线。
需要注意的是,这些代码将对所有的`TreeView`控件(不仅仅是本例中的这两个表格)应用相同的样式。如果只想对这两个表格应用所有线框,请将`style.configure`和`style.layout`方法的参数从`"Treeview"`改为相应的表格名称。
创建表格用于显示第一个工作表 columns1 = next(self.record_sheet.iter_rows(min_row=1, max_row=1, values_only=True)) treeview1 = ttk.Treeview(self.container1, columns=columns1, show="headings") treeview1.grid(row=1, column=3, rowspan=1, padx=5, pady=5, sticky="nsew") # 设置表格列的标题和宽度 for col in columns1: treeview1.heading(col, text=col) treeview1.column(col, width=100, anchor="center") # 显示第一个工作表的内容 for row in self.record_sheet.iter_rows(min_row=2, values_only=True): row_values = [cell if cell is not None else "" for cell in row] if all(not bool(cell) for cell in row_values): continue treeview1.insert("", tk.END, values=row_values) # 创建表格用于显示第二个工作表 columns2 = next(self.data_sheet.iter_rows(min_row=1, max_row=1, values_only=True)) treeview2 = ttk.Treeview(self.container1, columns=columns2, show="headings") treeview2.grid(row=3, column=3, padx=5, pady=5, sticky="nsew") # 设置表格列的标题和宽度 for col in columns2: treeview2.heading(col, text=col) treeview2.column(col, width=100, anchor="center") # 显示第二个工作表的内容 for row in self.data_sheet.iter_rows(min_row=2, values_only=True): row_values = [cell if cell is not None else "" for cell in row] if all(not bool(cell) for cell in row_values): continue treeview2.insert("", tk.END, values=row_values) # 设置文本框大小一致 self.material_name1.config(width=20) self.material_qty.config(width=20)怎麽將顯示在文本框中數據用邊框綫框起來
您可以使用 tkinter 的边框属性来为文本框添加边框线。例如,您可以使用以下代码为 material_name1 和 material_qty 的文本框添加边框线:
``` python
self.material_name1.config(highlightthickness=1, highlightbackground="black")
self.material_qty.config(highlightthickness=1, highlightbackground="black")
```
其中,`highlightthickness` 属性设置边框线的宽度,`highlightbackground` 属性设置边框线的颜色。您可以根据需要自行调整这些属性的值。
阅读全文