繁体   English   中英

如何在不重新运行程序的情况下在 tkinter 表上显示新添加的数据?

[英]How to display new add data on tkinter table without rerun the program?

我想在 tkinter 表上显示 sqlite 数据库,当我添加新数据时,我需要再次运行程序,然后新的数据会显示在表上。

如何编辑代码以将新数据与旧数据一起显示而无需再次运行数据? 我知道可以使用 .after( .after().update()但我不知道在哪里添加?

例如:(原始表格显示)
1

2


当我单击按钮“添加”时添加新数据“3”时,我想在表格上显示它

1

2

3

这是整个代码,谢谢帮助!

from tkinter import *
import tkinter as tk
import sqlite3


def add():
    b1 = Button(window,text = "Add",bg="lightblue",fg = "black",command=clicked)
    b1.grid(column=0,row=0)
    window.mainloop()

   
def clicked():
    def new():
        import sqlite3 #create new customer
        conn = sqlite3.connect('d:\\hw4.db')
        cursor = conn.cursor()
        name1=e_name.get()
        gender1=e_ged.get()
        birth1=e_bir.get()
        sql="insert into ss (name,gender,birth) values ('"+name1+"','"+gender1+"','"+birth1+"')"
        cursor.execute(sql)
        conn.commit()
        conn.close()
        top.destroy()
    top = Toplevel()
    top.title("New")
    #1
    name=Label(top,text="Name: ").grid(column=3,row=0,sticky='w')
    e_name=StringVar()
    e_name=Entry(top,text=e_name)
    e_name.grid(column=4,row=0)
    #2
    name=Label(top,text="Gender: ").grid(column=3,row=1,sticky='w')
    e_ged=StringVar()
    e_ged=Entry(top,text=e_ged)
    e_ged.grid(column=4,row=1)
    #3
    name=Label(top,text="Birth: ").grid(column=3,row=2,sticky='w')
    e_bir=StringVar()
    e_bir=Entry(top,text=e_bir)
    e_bir.grid(column=4,row=2)
    
    #add
    c=Button(top,text="Add",bg='lemonchiffon',fg='black',command=new)
    c.grid(column=3,row=4,sticky='w')
    top.mainloop()

    
    
def main():
    frame=Frame(window)
    import sqlite3
    conn = sqlite3.connect('d:\\hw4.db')
    cursor = conn.cursor()
    sql = 'select rowid,* from ss'
    cursor.execute(sql)
    result=cursor.fetchall();
    for r in range (len(result)):
        rlbls=[None,None,None,None,None,None]
        rlbls[0]=Label(frame,text=str(result[r][0]))
        rlbls[0].grid(column=0,row=r)
        rlbls[1]=Label(frame,text=str(result[r][1]))
        rlbls[1].grid(column=1,row=r)
        rlbls[2]=Label(frame,text=str(result[r][2]))
        rlbls[2].grid(column=2,row=r)
        rlbls[3]=Label(frame,text=str(result[r][3]))
        rlbls[3].grid(column=3,row=r)
        btn1 = Button(window, text="edit")
        btn1.grid(column=4, row=r+1)
        btn2 = Button(window, text="delete")
        btn2.grid(column=5, row=r+1)
        
    #show    
    conn=sqlite3.connect('d:\\hw4.db')
    c = conn.cursor()
    r = conn.execute('''SELECT * from ss''');
    i =1
    for n in r:
        for j in range(len(n)):
            e=Label(window,text=n[j])
            e.grid(column=j,row=i)
        i=i+1
    
       
    conn.commit()
    conn.close()
    return frame

window = Tk()
window.title("add")
window.geometry('200x200')

main()
add()

所以我做了一个简单的示例代码:

from tkinter import Tk, Label, Entry, Button


data = ['Info about 1', 'Info about 2']


def submit():
    given_data = user_input.get()
    user_input.delete(0, 'end')
    data.append(given_data)
    Label(root, text=given_data).pack()


root = Tk()

user_input = Entry(root)
user_input.pack()

submit_btn = Button(root, text='Submit', command=submit)
submit_btn.pack()

for value in data:
    Label(root, text=value).pack()

root.mainloop()

所以基本上这个重要的部分是你将拥有你的数据库并在提交 function 你只需 append 到你的数据库给定的信息,但你也将创建一个新的 ZB021DF6AAC4654C454F46C77646 立即用该信息打包它。 现在有 for 循环,所以基本上在您的情况下(您必须自己调整它)在启动程序时您仍然会始终读取数据库中的所有数据。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM