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列的内容輸入到下拉輸入框中
时间: 2024-03-10 12:47:07 浏览: 25
这段代码中的部分是用来打开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对象。