您的位置:

Python Access Listbox实现快速数据筛选和展示

一、基础概念

Listbox:Listbox是一种图形用户界面(GUI)小部件,通常用于显示文本或选择列表中的项目。

Python Tkinter:是一个用于Python编程语言的标准GUI工具包,它是Python内置的模块,无需额外安装。

结合Python Tkinter框架中的Listbox小部件,可以实现快速的数据筛选和展示。在本文中,我们将以展示不同地区销售数据为例,介绍如何使用Python Tkinter框架中的Listbox小部件实现快速数据筛选和展示。

二、绘制GUI界面

首先,我们需要绘制GUI界面。在这个界面中,我们要绘制一个表格和一个列表,用于展示数据。以下是界面绘制的代码:

    
    import tkinter as tk
    
    root = tk.Tk()
    root.title('数据筛选和展示')
    root.geometry('600x400')
    
    label_area = tk.Label(root, text='地区')
    label_area.grid(row=0, column=0, padx=10, pady=10)
    
    listbox_area = tk.Listbox(root)
    listbox_area.grid(row=0, column=1, padx=10, pady=10)
    
    label_table = tk.Label(root, text='数据表格')
    label_table.grid(row=1, column=0, padx=10, pady=10)
    
    frame_table = tk.Frame(root)
    frame_table.grid(row=1, column=1, padx=10, pady=10)
    
    root.mainloop()
    

代码解析:

  • 首先,我们导入了Tkinter模块,并创建了一个名为root的主窗口。
  • 接着,我们设置主窗口的标题和大小。
  • 然后,我们创建了一个文本标签label_area,用于显示“地区”文本,并设置其在第0行,第0列,边距为10的位置。
  • 接着,我们创建了一个列表框listbox_area,用于显示可选的地区列表,并设置其在第0行,第1列,边距为10的位置。
  • 然后,我们创建了一个文本标签label_table,用于显示“数据表格”文本,并设置其在第1行,第0列,边距为10的位置。
  • 接着,我们创建了一个框架frame_table,用于显示数据表格,并设置其在第1行,第1列,边距为10的位置。
  • <
  • 最后,我们通过root.mainloop()运行主窗口。

三、处理数据

接下来我们需要准备数据,并对其进行处理。在这个例子中,我们将使用一个Python列表来存储所有的销售数据。以下是数据处理的代码:

    
    sales_data = [
        {'region': '华北', 'product': '牛奶', 'sales': 5000},
        {'region': '华北', 'product': '面包', 'sales': 2000},
        {'region': '华北', 'product': '香肠', 'sales': 1500},
        {'region': '华东', 'product': '牛奶', 'sales': 3000},
        {'region': '华东', 'product': '面包', 'sales': 2500},
        {'region': '华东', 'product': '香肠', 'sales': 1000},
        {'region': '华南', 'product': '牛奶', 'sales': 6000},
        {'region': '华南', 'product': '面包', 'sales': 5000},
        {'region': '华南', 'product': '香肠', 'sales': 4000},
    ]
    
    # 获取所有地区
    regions = set()
    for data in sales_data:
        regions.add(data['region'])
        
    regions = list(regions)
    regions.sort()
    

代码解析:

  • 首先,我们创建了一个名为sales_data的Python列表,用于存储所有的销售数据。每条销售数据都是一个字典,包含了地区、产品和销售量三个属性。
  • 然后,我们通过遍历所有销售数据的方式,获取了所有地区,并以列表的形式存储。
  • 最后,我们对地区列表进行排序,以便在GUI界面中按照顺序显示。

四、绑定列表框和数据表格

接下来我们需要将列表框和数据表格绑定,并实现数据的动态显示。以下是绑定列表框和数据表格的代码:

    
    def show_data(region):
        # 删除原来的数据表格
        for widget in frame_table.winfo_children():
            widget.destroy()
        
        # 构建新的数据表格
        for i, data in enumerate(sales_data):
            if data['region'] == region:
                label_product = tk.Label(frame_table, text=data['product'])
                label_product.grid(row=i, column=0)
                
                label_sales = tk.Label(frame_table, text=data['sales'])
                label_sales.grid(row=i, column=1)
                
    for region in regions:
        listbox_area.insert(tk.END, region)
        
    region = regions[0]
    listbox_area.selection_set(0)
    show_data(region)
    
    def on_select(event):
        region = listbox_area.get(listbox_area.curselection())
        show_data(region)
    
    listbox_area.bind("<
   >", on_select)
    
   

代码解析:

  • 首先,我们创建了一个名为show_data的函数,用于根据选中的地区,在数据表格中显示相应的销售数据。
  • 然后,我们通过删除数据表格原有所有控件的方式,清空了数据表格。
  • 接着,我们通过遍历所有销售数据的方式,在数据表格中添加了与选中的地区相匹配的数据行。
  • 在主程序中,我们通过对地区列表的遍历,将所有地区都添加到了列表框中,并选中第一个地区。同时,我们还调用了show_data函数,展示了第一个地区的销售数据。
  • 最后,我们通过绑定“ListboxSelect”事件并传入on_select函数,来实现了当用户在列表框中选择不同地区时,数据表格的刷新和更新。

五、完整代码

    
    import tkinter as tk
    
    sales_data = [
        {'region': '华北', 'product': '牛奶', 'sales': 5000},
        {'region': '华北', 'product': '面包', 'sales': 2000},
        {'region': '华北', 'product': '香肠', 'sales': 1500},
        {'region': '华东', 'product': '牛奶', 'sales': 3000},
        {'region': '华东', 'product': '面包', 'sales': 2500},
        {'region': '华东', 'product': '香肠', 'sales': 1000},
        {'region': '华南', 'product': '牛奶', 'sales': 6000},
        {'region': '华南', 'product': '面包', 'sales': 5000},
        {'region': '华南', 'product': '香肠', 'sales': 4000},
    ]
    
    # 获取所有地区
    regions = set()
    for data in sales_data:
        regions.add(data['region'])
        
    regions = list(regions)
    regions.sort()
    
    def show_data(region):
        # 删除原来的数据表格
        for widget in frame_table.winfo_children():
            widget.destroy()
        
        # 构建新的数据表格
        for i, data in enumerate(sales_data):
            if data['region'] == region:
                label_product = tk.Label(frame_table, text=data['product'])
                label_product.grid(row=i, column=0)
                
                label_sales = tk.Label(frame_table, text=data['sales'])
                label_sales.grid(row=i, column=1)
    
    root = tk.Tk()
    root.title('数据筛选和展示')
    root.geometry('600x400')
    
    label_area = tk.Label(root, text='地区')
    label_area.grid(row=0, column=0, padx=10, pady=10)
    
    listbox_area = tk.Listbox(root)
    listbox_area.grid(row=0, column=1, padx=10, pady=10)
    
    label_table = tk.Label(root, text='数据表格')
    label_table.grid(row=1, column=0, padx=10, pady=10)
    
    frame_table = tk.Frame(root)
    frame_table.grid(row=1, column=1, padx=10, pady=10)
    
    for region in regions:
        listbox_area.insert(tk.END, region)
        
    region = regions[0]
    listbox_area.selection_set(0)
    show_data(region)
    
    def on_select(event):
        region = listbox_area.get(listbox_area.curselection())
        show_data(region)
    
    listbox_area.bind("<
   >", on_select)
    
    root.mainloop()