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) # 更新选中标签文本 data4 = self.la if not data4.endswith('.xlsx'): data4 += '.xlsx' # 拼接完整的文件路径 wo=r'\pcq-smt-ftp01\smt$\CQ SMT-單板測試課\2.生產組\點檢表\點檢歷史資料' filepath = os.path.join(wo, data4) print(filepath) # 判断文件是否存在,如果存在则打开,否则创建一个新的 Excel 文件 if os.path.exists(filepath): wb = openpyxl.load_workbook(filepath) print(f'{filepath}文件存在...') else: wb = openpyxl.Workbook() print(f'{filepath}創建好了') # 获取工作表并保存 ws = wb.active wb.save(filepath) # 清空左侧面板 for widget in self.sheet_frame.winfo_children(): widget.destroy() # 清空右下側面板 for widget in self.unique_listbox.winfo_children(): widget.destroy() # 在右下側添加文本標簽 for i, sheet_name in enumerate(self.sheet_names): label = tk.Label(self.unique_listbox, text=sheet_name) # 打开文件并筛选当天日期 workbook = xl.load_workbook(filepath) for sheet_name in self.sheet_names: sheet = workbook.active today = datetime.datetime.now().strftime('%Y/%m/%d') filtered_rows = [] for row in sheet.iter_rows(min_row=3): if row[2].value == today and row[8].value == sheet_name: filtered_rows.append(row) # 在右下側添加文本標簽 label = tk.Label(self.unique_listbox, text=sheet_name) if filtered_rows: label.config(text=f"{sheet_name} - 已點檢") else: label.config(text=f"{sheet_name} - 未點檢") label.grid(row=i // 5, column=i % 5, sticky="ew", padx=1, pady=1)這個代碼中爲什麽只比對了一個工作表,需要修改為所有工作表
时间: 2024-02-18 12:05:20 浏览: 101
在这段代码中,只比对了一个工作表是因为代码中只获取了当前活动的工作表,即 `sheet = workbook.active`。如果要比对所有工作表,可以改为循环遍历所有工作表,例如:
```
# 打开文件并筛选当天日期
workbook = xl.load_workbook(filepath)
for sheet_name in self.sheet_names:
sheet = workbook[sheet_name]
today = datetime.datetime.now().strftime('%Y/%m/%d')
filtered_rows = []
for row in sheet.iter_rows(min_row=3):
if row[2].value == today and row[8].value == sheet_name:
filtered_rows.append(row)
# 在右下側添加文本標簽
label = tk.Label(self.unique_listbox, text=sheet_name)
if filtered_rows:
label.config(text=f"{sheet_name} - 已點檢")
else:
label.config(text=f"{sheet_name} - 未點檢")
label.grid(row=i // 5, column=i % 5, sticky="ew", padx=1, pady=1)
```
这样就可以比对所有工作表了。
阅读全文