class InventoryApp: def init(self, master): self.master = master master.title("物料进出库统计") self.master.state('zoomed') # 窗口最大化 # 打开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.label12 = ttk.Label(self.container_top, text="數量:") self.label12.grid(row=1, column=0, padx=5, pady=5) self.material_qty12 = ttk.Combobox(self.container_top, values=[]) self.material_qty12.grid(row=1, column=1, padx=5, pady=5)self.label6 = ttk.Label(self.container_top, text="品名:") self.label6.grid(row=5, column=0, padx=5, pady=5) self.material_qty6 = ttk.Combobox(self.container_top, values=[]) self.material_qty6.grid(row=5, column=1, padx=5, pady=5)修改這個代碼,獲取第一個下拉輸入框中寫入的值,在打開的excel工作表名為數據的表匹配A列相應數據的第4列數據填寫到第2個下拉輸入框中
时间: 2024-03-10 10:45:20 浏览: 67
Python-Lectures-master.rar_Master Class_Python learning
你可以在代码中添加以下函数来实现这个功能:
```
import openpyxl
class InventoryApp:
def __init__(self, master):
self.master = master
master.title("物料进出库统计")
master.state('zoomed')
# 打开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.label12 = ttk.Label(self.container_top, text="數量:")
self.label12.grid(row=1, column=0, padx=5, pady=5)
self.material_qty12 = ttk.Combobox(self.container_top, values=[])
self.material_qty12.grid(row=1, column=1, padx=5, pady=5)
self.label6 = ttk.Label(self.container_top, text="品名:")
self.label6.grid(row=5, column=0, padx=5, pady=5)
self.material_qty6 = ttk.Combobox(self.container_top, values=[])
self.material_qty6.grid(row=5, column=1, padx=5, pady=5)
def get_material_qty(self):
material_qty_value = self.material_qty12.get()
for row in range(2, self.data_sheet.max_row+1):
if self.data_sheet.cell(row=row, column=1).value == material_qty_value:
self.material_qty6.set(self.data_sheet.cell(row=row, column=4).value)
break
```
然后在你的代码中调用此函数,如下所示:
```
self.material_qty12.bind("<<ComboboxSelected>>", lambda event: self.get_material_qty())
```
这将在选择第一个下拉框中的值时调用 `get_material_qty()` 函数,该函数将从 Excel 文件中读取数据并将其填充到第二个下拉框中。请将 `r"C:\Users\bing3_chen\Desktop\1.xlsx"` 更改为你的 Excel 文件路径。
阅读全文