def show_excel(self): self.wb = openpyxl.load_workbook(r"C:\Users\bing3_chen\Desktop\1.xlsx") self.record_sheet = self.wb["記錄"] self.data_sheet = self.wb["數據"] style = ttk.Style() style.configure("MyTreeview1.Treeview", rowheight=25, borderwidth=2, relief="solid", font=('Arial', 10)) style.configure("MyTreeview1.Treeview.Heading", font=('Arial', 10, 'bold')) style.layout("MyTreeview1.Treeview", [('MyTreeview1.Treeview.treearea', {'sticky': 'nswe'})]) # 创建表格用于显示第一个工作表 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) # 设置表格列的标题和宽度 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) # 创建表格用于显示第二个工作表 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") treeview2.config(height=10) # 显示第二个工作表的内容 for row in self.data_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 treeview2.insert("", tk.END, values=row_values)這段代碼未將excel數據顯示完整,有的數據列被窗口擋住了,怎麽修改
时间: 2024-02-14 09:14:36 浏览: 63
可以尝试修改以下几个地方:
1. 修改表格的高度:在创建表格时,通过 `treeview1.config(height=10)` 和 `treeview2.config(height=10)` 来设置表格的高度,可以将这个值调大一些,比如改成 `treeview1.config(height=20)`。
2. 修改表格的位置:可以将表格的位置调整一下,让它们不被窗口挡住。比如将第一个表格的 `row` 改成 2,第二个表格的 `row` 改成 4,或者将它们的 `column` 值调整一下。
3. 调整列宽:可以通过 `treeview1.column(col, width=100, anchor="center")` 和 `treeview2.column(col, width=100, anchor="center")` 来调整列宽,将宽度调大一些,比如改成 `treeview1.column(col, width=150, anchor="center")`。
通过以上修改,可以让表格显示更完整。另外,如果表格还是显示不完整,可以尝试将窗口的大小调整一下,让它更大一些。
相关问题
def show_excel(self): self.wb = openpyxl.load_workbook(r"C:\Users\bing3_chen\Desktop\1.xlsx") self.record_sheet = self.wb["記錄"] self.data_sheet = self.wb["數據"] rows = self.record_sheet.iter_rows(min_row=1, values_only=True) records = [] header = next(rows) # 将数据插入到文本框中 for row in records: row_str = '' for col in row: row_str += str(col) + '\t' self.result_text.insert(tk.END, row_str + '\n')怎麽將excel表名是數據表中所有内容顯示到文本框中
要将Excel表名为“數據表”中的所有内容显示到文本框中,您可以使用以下代码:
```
def show_excel(self):
self.wb = openpyxl.load_workbook(r"C:\Users\bing3_chen\Desktop\1.xlsx")
self.data_sheet = self.wb["數據表"] # 将工作表命名为"數據表"
rows = self.data_sheet.iter_rows(min_row=1, values_only=True)
records = []
header = next(rows)
# 将数据插入到文本框中
for row in rows:
row_str = ''
for col in row:
row_str += str(col) + '\t'
self.result_text.insert(tk.END, row_str + '\n')
```
在此代码中,我们将工作表命名为“數據表”,并使用该名称从工作簿中获取数据表。然后,我们使用该数据表中的所有行来填充记录列表,并将其插入到文本框中。请注意,这里我们使用的是数据表的所有行,而不是只使用第一行之后的行,因为我们想要显示所有数据。
class InventoryApp: def __init__(self, master): self.master = master master.title("物料进出库统计") self.master.state('zoomed') # 窗口最大化 # 创建左侧面板 self.container = tk.Frame(master) self.container.pack(side=tk.LEFT, fill=tk.BOTH, expand=True) # 创建左上方面板 self.container_top = tk.Frame(self.container) self.container_top.pack(side=tk.TOP, fill=tk.BOTH, expand=True)打开Excel文件 self.wb = openpyxl.load_workbook(r"C:\Users\bing3_chen\Desktop\1.xlsx") self.record_sheet = self.wb["記錄"] self.data_sheet = self.wb["數據"]self.material_name11.get() self.label14 = ttk.Label(self.container_top, text="品名:") self.label14.grid(row=5, column=0, padx=5, pady=5) self.material_qty14 = ttk.Combobox(self.container_top, values=[]) self.material_qty14.grid(row=5, column=1, padx=5, pady=5)在這段代碼中根據self.material_name11.get()獲取的内容去excel表名為數據的表中從第一列匹配到相應數據的第5列的内容輸入到下拉輸入框中
这段代码中的部分是用来打开Excel文件并将相应数据输入到下拉输入框中的。
首先,使用openpyxl库打开Excel文件,如下所示:
```
self.wb = openpyxl.load_workbook(r"C:\Users\bing3_chen\Desktop\1.xlsx")
self.record_sheet = self.wb["記錄"]
self.data_sheet = self.wb["數據"]
```
接下来,使用self.material_name11.get()获取下拉输入框中选择的内容,并从表名为"數據"的工作表中匹配相应数据。可以使用sheet.iter_rows()函数遍历工作表的每一行,并使用row[0].value获取每一行的第一列的值,然后将其与获取的下拉输入框的值进行比较,如果匹配成功则使用sheet.cell()函数获取相应的单元格的值,并将其添加到下拉输入框中,如下所示:
```
# 根据获取的内容匹配相应的数据并输入到下拉输入框中
if self.material_name11.get() in material_names:
for row in self.data_sheet.iter_rows(min_row=1, max_row=self.data_sheet.max_row, min_col=1, max_col=self.data_sheet.max_column):
if row[0].value == self.material_name11.get():
material_qty = row[4].value
self.material_qty14['values'] = [material_qty]
```
注意,这里使用了self.material_qty14['values']来设置下拉输入框的值,因为它是一个ttk.Combobox对象。
阅读全文