# 显示excel内容的回调函数 def show_excel(self): # 创建表格用于显示第一个工作表 columns1 = [col[0] for col in self.record_sheet.iter_cols()] 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(values_only=True): treeview1.insert("", tk.END, values=row) # 创建表格用于显示第二个工作表 columns2 = [col[0] for col in self.data_sheet.iter_cols()] 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(values_only=True): treeview2.insert("", tk.END, values=row) # 设置文本框大小一致 self.material_name1.config(width=20) self.material_qty.config(width=20) # treeview1.config(minwidth=80) # treeview2.config(minwidth=80)修改這個代碼,如果單元格為空,那顯示數據時就不顯示
时间: 2024-01-14 11:01:58 浏览: 19
可以在插入每行数据的时候,判断该行数据是否为空,如果为空则不插入。可以使用Python内置的bool()函数判断一个值是否为空,示例代码如下:
```
for row in self.record_sheet.iter_rows(values_only=True):
if all(not bool(cell) for cell in row):
continue
treeview1.insert("", tk.END, values=row)
```
其中,all()函数判断一个可迭代对象中所有元素是否都为真,如果都为真则返回True,否则返回False。在这里,我们使用了not bool(cell)来判断单元格是否为空,如果为空则返回True,否则返回False。如果一行中所有单元格都为空,则all()函数返回True,这时我们就跳过该行数据,不插入到表格中。
相关问题
class InventoryApp: def init(self, master): self.master = master master.title("物料进出库统计") # 创建标签和文本框 self.label1 = tk.Label(master, text="物料名称:") self.label1.grid(row=0, column=0, padx=5, pady=5) self.material_name = tk.Entry(master) self.material_name.grid(row=0, column=1, padx=5, pady=5) self.label2 = tk.Label(master, text="数量:") self.label2.grid(row=1, column=0, padx=5, pady=5) self.material_qty = tk.Entry(master) self.material_qty.grid(row=1, column=1, padx=5, pady=5) # 创建进出库按钮 self.in_button = tk.Button(master, text="进库", command=self.in_stock) self.in_button.grid(row=2, column=0, padx=5, pady=5) self.out_button = tk.Button(master, text="出库", command=self.out_stock) self.out_button.grid(row=2, column=1, padx=5, pady=5) # 添加显示excel内容的按钮 self.show_button = tk.Button(master, text="显示Excel内容", command=self.show_excel) self.show_button.grid(row=3, column=0, padx=5, pady=5) # 打开Excel文件 self.wb = openpyxl.load_workbook(r"C:\Users\bing3_chen\Desktop\1.xlsx") self.record_sheet = self.wb["記錄"] self.data_sheet = self.wb["數據"] # 显示excel内容的回调函数 def show_excel(self): # 创建一个新窗口 top = tk.Toplevel(self.master) # 创建表格用于显示第一个工作表 columns1 = [col[0] for col in self.record_sheet.iter_cols()] treeview1 = ttk.Treeview(top, columns=columns1, show="headings") treeview1.grid(row=0, column=0, padx=5, pady=5) # 设置表格列的标题和宽度 for col in columns1: treeview1.heading(col, text=col) treeview1.column(col, width=100, anchor="center") # 显示第一个工作表的内容 for row in self.record_sheet.iter_rows(values_only=True): treeview1.insert("", tk.END, values=row) # 创建表格用于显示第二个工作表 columns2 = [col[0] for col in self.data_sheet.iter_cols()] treeview2 = ttk.Treeview(top, columns=columns2, show="headings") treeview2.grid(row=1, column=0, padx=5, pady=5) # 设置表格列的标题和宽度 for col in columns2: treeview2.heading(col, text=col) treeview2.column(col, width=100, anchor="center") # 显示第二个工作表的内容 for row in self.data_sheet.iter_rows(values_only=True): treeview2.insert("", tk.END, values=row)修改這個代碼不打開新的窗口,就在原本窗口的右側顯示,并且兩個文本框大小一致,
你可以尝试以下修改代码:
1. 首先,需要在主窗口中添加一个容器,用于放置表格和文本框。
2. 然后,将显示excel内容的按钮的回调函数修改为在容器中创建表格,而不是打开新窗口。
3. 最后,将两个文本框的大小设置为一致。
修改后的代码如下:
```
class InventoryApp:
def __init__(self, master):
self.master = master
master.title("物料进出库统计")
# 创建容器,用于放置表格和文本框
self.container = tk.Frame(master)
self.container.grid(row=0, column=0, padx=5, pady=5)
# 创建标签和文本框
self.label1 = tk.Label(self.container, text="物料名称:")
self.label1.grid(row=0, column=0, padx=5, pady=5)
self.material_name = tk.Entry(self.container, width=20)
self.material_name.grid(row=0, column=1, padx=5, pady=5)
self.label2 = tk.Label(self.container, text="数量:")
self.label2.grid(row=1, column=0, padx=5, pady=5)
self.material_qty = tk.Entry(self.container, width=20)
self.material_qty.grid(row=1, column=1, padx=5, pady=5)
# 创建进出库按钮
self.in_button = tk.Button(self.container, text="进库", command=self.in_stock)
self.in_button.grid(row=2, column=0, padx=5, pady=5)
self.out_button = tk.Button(self.container, text="出库", command=self.out_stock)
self.out_button.grid(row=2, column=1, padx=5, pady=5)
# 添加显示excel内容的按钮
self.show_button = tk.Button(self.container, text="显示Excel内容", command=self.show_excel)
self.show_button.grid(row=3, column=0, columnspan=2, padx=5, pady=5)
# 打开Excel文件
self.wb = openpyxl.load_workbook(r"C:\Users\bing3_chen\Desktop\1.xlsx")
self.record_sheet = self.wb["記錄"]
self.data_sheet = self.wb["數據"]
# 显示excel内容的回调函数
def show_excel(self):
# 创建表格用于显示第一个工作表
columns1 = [col[0] for col in self.record_sheet.iter_cols()]
treeview1 = ttk.Treeview(self.container, columns=columns1, show="headings")
treeview1.grid(row=0, column=2, rowspan=2, 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(values_only=True):
treeview1.insert("", tk.END, values=row)
# 创建表格用于显示第二个工作表
columns2 = [col[0] for col in self.data_sheet.iter_cols()]
treeview2 = ttk.Treeview(self.container, columns=columns2, show="headings")
treeview2.grid(row=2, column=2, 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(values_only=True):
treeview2.insert("", tk.END, values=row)
# 设置文本框大小一致
self.material_name.config(width=20)
self.material_qty.config(width=20)
```
# 显示excel内容的回调函数 def show_excel(self): # 创建表格用于显示第一个工作表 columns1 = [col[0] for col in self.record_sheet.iter_cols()] 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(values_only=True): treeview1.insert("", tk.END, values=row) # 创建表格用于显示第二个工作表 columns2 = [col[0] for col in self.data_sheet.iter_cols()] 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(values_only=True): treeview2.insert("", tk.END, values=row) # 设置文本框大小一致 self.material_name1.config(width=20) self.material_qty.config(width=20) # treeview1.config(minwidth=80) # treeview2.config(minwidth=80)什麽意思
这段代码是展示Excel表格内容的回调函数。它使用了Python的openpyxl库来读取Excel文件中的内容,并使用tkinter和ttk库来创建GUI界面并展示Excel表格内容。具体来说,该函数会创建两个表格来展示Excel文件中的两个工作表的内容,并设置表格的列标题和列宽度,最后将每个单元格的数据插入到表格中。
注释部分的代码是对表格宽度的设置,但被注释掉了,你可以根据需要进行修改。