簡體   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