av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

python制作一個(gè)簡(jiǎn)單的gui 數(shù)據(jù)庫(kù)查詢界面

瀏覽:4日期:2022-07-04 18:37:05

一、準(zhǔn)備工作:

1、安裝mysql3.7,創(chuàng)建一個(gè)test數(shù)據(jù)庫(kù),創(chuàng)建student表,創(chuàng)建列:(列名看代碼),創(chuàng)建幾條數(shù)據(jù)

(以上工作直接用navicat for mysql工具完成)

二、代碼:

import sysimport tkinter as tkimport mysql.connector as sql#--------------------查詢函數(shù)---------------------------def sql_connect(): listbox_show.delete(0,’end’) #初始化清空顯示區(qū) m = listbox_name.curselection()[0] print(’m=’,m) list_name = listbox_name.get(m)[0] varlue = entry_varlue.get() print(’list_name=’,list_name) print(’var=’,varlue) while list_name == ’Student_ID’: sql_sr = 'select * from Student where student.student_id = ' + '’' + varlue +'’' print(sql_sr) break while list_name == ’Name’: sql_sr = 'select * from Student where student.name = ' + '’' + varlue +'’' print(sql_sr) break while list_name == ’Age’: sql_sr = 'select * from Student where student.age = ' + '’' + varlue +'’' print(sql_sr) break while list_name == ’Sex’: sql_sr = 'select * from Student where student.sex = ' + '’' + varlue +'’' print(sql_sr) break while list_name == ’Class’: sql_sr = 'select * from Student where student.class = ' + '’' + varlue +'’' print(sql_sr) break mydb = sql.connect(host=’localhost’,user=’root’,passwd=’123456’,database=’test’) mycursor = mydb.cursor() mycursor.execute(sql_sr) myresult = mycursor.fetchall() for x in myresult: print (x) listbox_show.insert(’end’,x)#--------------------------------------------------------#------------界面初始化時(shí)加載選項(xiàng)列表--------------------sql_n = 'SELECT COLUMN_NAME FROM information_schema.COLUMNS WHERE TABLE_SCHEMA = ’test’ AND TABLE_NAME = ’student’'mydb = sql.connect(host=’localhost’,user=’root’,passwd=’123456’,database=’test’)mycursor = mydb.cursor()mycursor.execute(sql_n)myresult = mycursor.fetchall()#--------------------------------------------------------#----------窗體部分--------------------------------------entry_list_name = tk.Entry()entry_list_name.pack()listbox_name = tk.Listbox()listbox_name.pack()for i in myresult: listbox_name.insert(’end’,i) #加載選項(xiàng)列表entry_varlue = tk.Entry()entry_varlue.pack()button_select = tk.Button(text = ’查找’,command = sql_connect)button_select.pack()listbox_show = tk.Listbox()listbox_show.pack()root.mainloop()#--------------------------------------------------------

三、界面

python制作一個(gè)簡(jiǎn)單的gui 數(shù)據(jù)庫(kù)查詢界面

好吧,是挺丑的,因?yàn)闆](méi)調(diào)格式,將就吧。

四、總結(jié)

1、目的:自己這個(gè)菜鳥新手天天看基礎(chǔ)教程覺(jué)得很抽象,各種運(yùn)算結(jié)果只能打印在IDE窗口,不是我想象中的程序(有界面,有交互,有。。。總之很精彩),然后按教程的各種漸進(jìn)學(xué)法感覺(jué)不太適合自己的風(fēng)格,我喜歡有一個(gè)具體的東西,不斷的添加功能,然后在添加的過(guò)程中碰到問(wèn)題再尋求解決辦法,在解決的過(guò)程中學(xué)習(xí)新知識(shí),嗯,就是只學(xué)能用到的,很功利。。。然后就開始折騰這個(gè)小界面。

2、首先要有GUI界面就要用到GUI模塊,本著方便原則就用python自帶的tkinter(不用再折騰安裝),一開始我想用所見即所得的方式,找到了一個(gè)可以拖放元件來(lái)生成界面的工具page python,這也是個(gè)基于tkinter的工具,后來(lái)發(fā)現(xiàn)生成的py文件對(duì)我這個(gè)菜鳥來(lái)說(shuō)還是有點(diǎn)深?yuàn)W了,而且關(guān)于page的教程全網(wǎng)只有一兩個(gè)(無(wú)語(yǔ),估計(jì)高手都不屑吧),然后就轉(zhuǎn)而直接研究tkinter

3、先做好窗體部分的實(shí)現(xiàn)代碼。

設(shè)計(jì):按動(dòng)按鈕查詢固定表里某一字段的某個(gè)匹配值的結(jié)果,顯示在界面中。

元件:輸入元件2個(gè)(1個(gè)字段,1個(gè)值),結(jié)果顯示元件1個(gè),按鈕1個(gè)。

字段輸入值直接獲取表頭列出選擇,找不到下拉菜單,只能用listbox來(lái)做,界面初始化時(shí)就將表頭讀出列在listbox里。

匹配值輸入使用entry輸入框。

顯示結(jié)果也是使用listbox。

交互動(dòng)作使用按鈕。

OK,視覺(jué)界面做好了,下面添加功能。

4、(字段輸入值直接獲取表頭列出選擇,找不到下拉菜單,只能用listbox來(lái)做,界面初始化時(shí)就將表頭讀出列在listbox里。)

要和mysql交互獲取,需要登錄數(shù)據(jù)庫(kù)并實(shí)現(xiàn)查詢。

我使用import mysql.connector模塊來(lái)實(shí)現(xiàn)和mysql的通訊(python還有期它模塊也能實(shí)現(xiàn)和mysql的通訊,當(dāng)時(shí)為什么使用mysql.connector呢,我也記不清了,好像從哪個(gè)教程直接弄來(lái)用的,反正就是用了)

于是又去啃了sql的查詢語(yǔ)句,這里還是挺齊全的https://www.runoob.com/sql/sql-select.html,不過(guò)我是沒(méi)學(xué)全的,沒(méi)辦法,學(xué)渣只能用到哪學(xué)到哪。重點(diǎn)說(shuō)一下,sql語(yǔ)句里的 + 號(hào)就是將前后的值串起來(lái),可以理解為and。可以將字符和變量串起來(lái)。

5、接下來(lái)就是按鈕動(dòng)作的交互代碼了,這是邏輯的重頭戲。

邏輯:在列出的字段中選擇一個(gè)要查詢的字段,輸入要匹配的值,點(diǎn)擊按鈕查詢,將結(jié)果顯示在顯示區(qū)。

獲取listbox的光標(biāo)值,將它取出來(lái),比對(duì)字段生成相應(yīng)的sql查詢語(yǔ)句,和mysql交互得到返回值集,逐條取出展示在顯示區(qū)。

好了,大功告成,雖然看起來(lái)很丑,想讓它變美女就要加濾鏡咯(調(diào)tkinter格式)。

以上就是python制作一個(gè)簡(jiǎn)單的gui 數(shù)據(jù)庫(kù)查詢界面的詳細(xì)內(nèi)容,更多關(guān)于python gui數(shù)據(jù)庫(kù)查詢的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 久久国产一区二区 | 久久99国产精品 | 午夜精品一区二区三区在线视频 | 亚洲精品久久国产高清情趣图文 | 国产成人在线一区二区 | 国产精品美女久久久久aⅴ国产馆 | 国产探花在线精品一区二区 | 午夜一区二区三区在线观看 | 久久精品久久综合 | 久久精品色欧美aⅴ一区二区 | 九九看片 | 91动漫在线观看 | 日韩在线h | 电影91久久久 | 蜜桃精品视频在线 | 国产美女久久 | 91在线免费观看网站 | 日韩中文字幕一区 | 久久成人一区 | 国产福利91精品一区二区三区 | 九九热视频这里只有精品 | 国产成人综合在线 | 国产 欧美 日韩 一区 | 91爱啪啪 | 午夜男人视频 | 91免费电影 | 国产高清视频一区 | 欧美伊人影院 | 国产精品亚洲一区二区三区在线 | 日日天天 | 亚洲视频 欧美视频 | 天天射影院 | 久久久久久综合 | av在线免费观看网站 | 成人av鲁丝片一区二区小说 | 日日骚av| 久久精品一区二 | 国产精品视频入口 | 拍真实国产伦偷精品 | 日韩av成人 | 亚洲国产偷 |