一、基础概念
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()