我想使用Tkinter创建一个搜索表单,用户可以在其中输入他们想要从SQLite3数据库中看到的名称。名为New_Assignment的数据库包含有关此人的所有详细信息。但我对如何将Tkinter连接到数据库并使用名称进行搜索感到困惑?这就是我到目前为止所做的。
import sqlite3
conn = sqlite3.connect('new_assignment.db')
c = conn.cursor()
from tkinter import *
top = Tk()
top.title('Search form')
person_name = Entry()
person_name.pack(side = RIGHT, expand = True)
mainloop()
答案 0 :(得分:0)
要从Entry
窗口小部件获取文本,请使用get()
方法(它返回文本框中的字符串)。
name_box = Entry()
name_box.pack(side=RIGHT, expand=True)
person_name = name_box.get()
但是,你将需要添加一个按钮,如@abarnert在评论中所说。将此功能附加到它:
def get_name():
global person_name
person_name = name_box.get()
data = c.fetchall()
print(data)
for row in data:
searchlist.append(row)
var1=str(person_name)
read_from_db(var1)
(当然,修改read_from_db()
以获取如此变量:
def read_from_db(var):
curs.execute("SELECT *" + " FROM personal WHERE Name LIKE (?)", ('%'+var+'%',))
)
按钮代码的示例可能如下所示:
button = Button(top, text="Display text", command=get_name)
将它们放在一起:
import sqlite3
conn = sqlite3.connect('new_assignment.db')
c = conn.cursor()
from tkinter import *
top = Tk()
top.title('Search form')
name_box = Entry()
name_box.pack(side = RIGHT, expand = True)
def get_name():
global person_name
person_name = name_box.get()
data = c.fetchall()
print(data)
for row in data:
searchlist.append(row)
var1=str(person_name)
read_from_db(var1)
def read_from_db(var):
curs.execute("SELECT *" + " FROM personal WHERE Name LIKE (?)", ('%'+var+'%',))
person_name = ""
button = Button(top, text="Display text", command=get_name)
button.pack()
mainloop()