def display_data(): # 打开excel文件 wb = openpyxl.load_workbook('user_info.xlsx') sheet = wb.active # 创建表格 table = ttk.Treeview(root, columns=('col1', 'col2', 'col3'), show='headings') table.column('col1', width=100, anchor='center') table.column('col2', width=100, anchor='center') table.column('col3', width=100, anchor='center') table.heading('col1', text='用户名') table.heading('col2', text='密码') table.heading('col3', text='用户ID') table.grid(row=4, column=0, columnspan=3, padx=10, pady=10) # 填充数据 for row in sheet.iter_rows(min_row=2, values_only=True): table.insert('', tk.END, values=row) # 绑定双击事件 def on_double_click(event): item = table.selection()[0] values = table.item(item, 'values') username_entry.delete(0, tk.END) password_entry.delete(0, tk.END) id_entry.delete(0, tk.END) username_entry.insert(0, values[0]) password_entry.insert(0, values[1]) id_entry.insert(0, values[2]) table.bind('<Double-1>', on_double_click)把这段代码改成弹出一个窗口
时间: 2024-01-06 12:05:36 浏览: 35
好的,以下是修改后的代码,它会弹出一个窗口来显示数据:
```python
import tkinter as tk
from tkinter import ttk
import openpyxl
def display_data():
# 打开excel文件
wb = openpyxl.load_workbook('user_info.xlsx')
sheet = wb.active
# 创建窗口
window = tk.Toplevel()
window.title('用户信息')
# 创建表格
table = ttk.Treeview(window, columns=('col1', 'col2', 'col3'), show='headings')
table.column('col1', width=100, anchor='center')
table.column('col2', width=100, anchor='center')
table.column('col3', width=100, anchor='center')
table.heading('col1', text='用户名')
table.heading('col2', text='密码')
table.heading('col3', text='用户ID')
table.pack(side='top', padx=10, pady=10)
# 填充数据
for row in sheet.iter_rows(min_row=2, values_only=True):
table.insert('', tk.END, values=row)
# 绑定双击事件
def on_double_click(event):
item = table.selection()[0]
values = table.item(item, 'values')
username_entry.delete(0, tk.END)
password_entry.delete(0, tk.END)
id_entry.delete(0, tk.END)
username_entry.insert(0, values[0])
password_entry.insert(0, values[1])
id_entry.insert(0, values[2])
table.bind('<Double-1>', on_double_click)
# 创建输入框
username_label = tk.Label(window, text='用户名:')
username_label.pack(side='left', padx=10, pady=10)
username_entry = tk.Entry(window)
username_entry.pack(side='left', padx=10, pady=10)
password_label = tk.Label(window, text='密码:')
password_label.pack(side='left', padx=10, pady=10)
password_entry = tk.Entry(window)
password_entry.pack(side='left', padx=10, pady=10)
id_label = tk.Label(window, text='用户ID:')
id_label.pack(side='left', padx=10, pady=10)
id_entry = tk.Entry(window)
id_entry.pack(side='left', padx=10, pady=10)
# 创建按钮
save_button = tk.Button(window, text='保存')
save_button.pack(side='left', padx=10, pady=10)
cancel_button = tk.Button(window, text='取消', command=window.destroy)
cancel_button.pack(side='left', padx=10, pady=10)
# 创建主窗口
root = tk.Tk()
# 创建按钮
display_button = tk.Button(root, text='显示数据', command=display_data)
display_button.grid(row=0, column=0, padx=10, pady=10)
# 运行主窗口
root.mainloop()
```
这个修改后的代码会创建一个弹出窗口,窗口中包含一个表格来显示数据,以及输入框和按钮来进行编辑和保存。双击表格中的一行数据时,会自动将对应的用户名、密码和用户ID填充到输入框中。保存按钮的功能需要你自己来实现。