for name in right_list: if name not in left_list: list_data.append(name)匹配不出数据
时间: 2024-05-20 10:13:26 浏览: 62
这段代码的作用是从 `right_list` 列表中找出不在 `left_list` 列表中的元素,并将其添加到 `list_data` 列表中。如果你使用这段代码后匹配不出数据,可能有以下几种原因:
1. `right_list` 和 `left_list` 中的元素没有被正确定义,你需要检查这两个列表是否包含你想要匹配的数据。
2. `right_list` 中的元素已经包含在 `left_list` 中,这时它不会被添加到 `list_data` 列表中。你需要检查这两个列表是否有相同的元素。
3. `list_data` 列表没有被正确定义,你需要检查它是否被正确创建。
你可以对代码进行调试,查看具体的错误信息,以便更好地定位问题。
相关问题
class InventoryApp: def init(self, master): self.master = master master.title("物料进出库统计") 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) # 创建左下方面板 self.container_bottom = tk.Frame(self.container) self.container_bottom.pack(side=tk.BOTTOM, 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["數據"] # 从工作表中获取数据并写入下拉框中 data_list = [] for row in range(2, self.data_sheet.max_row + 1): cell_value = self.data_sheet.cell(row=row, column=1).value if cell_value: data_list.append(cell_value) def on_material_name_keyrelease(event): # 获取用户输入的内容 user_input = self.material_name11.get() if not user_input: # 如果用户没有输入任何内容,则展示所有选项 self.material_name11.configure(values=data_list) else: # 根据用户输入的内容过滤下拉框的选项 filtered_options = [option for option in data_list if user_input in option] if filtered_options: # 如果有符合条件的选项,则更新下拉框的选项并展开下拉框 self.material_name11.configure(values=filtered_options) self.material_name11.event_generate('<Down>') # 根据用户输入的内容在数据表中筛选出对应的行 for row in range(2, self.data_sheet.max_row + 1): cell_value = self.data_sheet.cell(row=row, column=1).value if cell_value == user_input: # 找到对应的行后,将第4列的值填入material_qty14中 self.material_qty14.set(self.data_sheet.cell(row=row, column=4).value) break else: # 如果没有符合条件的选项,则关闭下拉框 self.material_name11.event_generate('<Escape>') # 创建标签 self.label10 = ttk.Label(self.container_top, text="PEGA-料号:") self.label10.grid(row=0, column=0, padx=5, pady=5) # 获取品名列表 self.label14 = ttk.Label(self.container_bottom, text="品名:") self.label14.grid(row=5, column=0, padx=5, pady=5) self.material_qty14 = ttk.Combobox(self.container_bottom, values=[]) self.material_qty14.grid(row=5, column=1, padx=5, pady=5) # 创建下拉框 self.material_name11 = ttk.Combobox(self.container_top, values=data_list) self.material_name11.grid(row=0, column=1, padx=5, pady=5) self.material_name11.bind('<KeyRelease>', on_material_name_keyrelease)material_qty14 沒有獲取到相應的數據
从您提供的代码来看,当用户在下拉框中选择一个物料名称时,会触发 `on_material_name_keyrelease` 函数,然后根据用户输入的物料名称,在数据表中筛选出对应的行,并将该行的第四列数据填充到 `material_qty14` 中。但是,我没有看到在哪里给 `material_qty14` 设置了初始值。
如果 `material_qty14` 没有獲取到相應的數據,可能是因为没有匹配到用户输入的物料名称,或者是没有在数据表中找到与用户输入的物料名称对应的行。您可以在 `on_material_name_keyrelease` 函数中加入一些调试信息,以便更好地定位问题。例如,在没有找到匹配的行时,可以在控制台输出一些消息,查看程序运行时的问题所在。
另外,您可以检查一下数据表中的数据是否正确,并确认您输入的物料名称在数据表中是否存在。
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) # 创建左下方面板 self.container_bottom = tk.Frame(self.container) self.container_bottom.pack(side=tk.BOTTOM, 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["數據"]# 从工作表中获取数据并写入下拉框中 data_list = [] for row in range(2, self.data_sheet.max_row + 1): cell_value = self.data_sheet.cell(row=row, column=1).value if cell_value: data_list.append(cell_value) def on_material_name_keyrelease(event): # 获取用户输入的内容 user_input = self.material_name11.get() if not user_input: # 如果用户没有输入任何内容,则展示所有选项 self.material_name11.configure(values=data_list) else: # 根据用户输入的内容过滤下拉框的选项 filtered_options = [option for option in data_list if user_input in option] if filtered_options: # 如果有符合条件的选项,则更新下拉框的选项并展开下拉框 self.material_name11.configure(values=filtered_options) self.material_name11.event_generate('<Down>') else: # 如果没有符合条件的选项,则关闭下拉框 self.material_name11.event_generate('<Escape>') # 创建标签 self.label10 = ttk.Label(self.container_top, text="PEGA-料号:") self.label10.grid(row=0, column=0, padx=5, pady=5)# 获取品名列表 self.label14 = ttk.Label(self.container_bottom, text="品名:") self.label14.grid(row=5, column=0, padx=5, pady=5) self.material_qty14 = ttk.Combobox(self.container_bottom, values=[]) self.material_qty14.grid(row=5, column=1, padx=5, pady=5)
这是一个使用Python Tkinter库开发的物料进出库统计应用程序。应用程序的主要窗口被分成了左右两部分,其中左侧面板被进一步分成了左上方面板和左下方面板。应用程序从一个Excel文件中读取数据,并将数据填充到下拉框中。用户可以在输入框中输入内容,下拉框会根据用户输入的内容进行过滤,并展示符合条件的选项。应用程序还包括了一些标签和组件,比如标签“PEGA-料号”和下拉框“material_qty14”。
阅读全文