python+tkinter+mysql做簡單數據庫查詢界面
一、準備工作:
1、安裝mysql3.7,創(chuàng)建一個test數據庫,創(chuàng)建student表,創(chuàng)建列:(列名看代碼),創(chuàng)建幾條數據
(以上工作直接用navicat for mysql工具完成)
二、代碼:
import sys import tkinter as tk import mysql.connector as sql #--------------------查詢函數--------------------------- 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) #-------------------------------------------------------- #------------界面初始化時加載選項列表-------------------- 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) #加載選項列表 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() #--------------------------------------------------------
三、界面
好吧,是挺丑的,因為沒調格式,將就吧。
四、總結
1、目的:自己這個菜鳥新手天天看基礎教程覺得很抽象,各種運算結果只能打印在IDE窗口,不是我想象中的程序(有界面,有交互,有。。。總之很精彩),然后按教程的各種漸進學法感覺不太適合自己的風格,我喜歡有一個具體的東西,不斷的添加功能,然后在添加的過程中碰到問題再尋求解決辦法,在解決的過程中學習新知識,嗯,就是只學能用到的,很功利。。。然后就開始折騰這個小界面。
2、首先要有GUI界面就要用到GUI模塊,本著方便原則就用python自帶的tkinter(不用再折騰安裝),一開始我想用所見即所得的方式,找到了一個可以拖放元件來生成界面的工具page python,這也是個基于tkinter的工具,后來發(fā)現生成的py文件對我這個菜鳥來說還是有點深奧了,而且關于page的教程全網只有一兩個(無語,估計高手都不屑吧),然后就轉而直接研究tkinter,以下是幾個有用的鏈接:http://www.dbjr.com.cn/article/197751.htm?pc
http://www.dbjr.com.cn/article/234305.htm
3、先做好窗體部分的實現代碼。
設計:按動按鈕查詢固定表里某一字段的某個匹配值的結果,顯示在界面中。
元件:輸入元件2個(1個字段,1個值),結果顯示元件1個,按鈕1個。
字段輸入值直接獲取表頭列出選擇,找不到下拉菜單,只能用listbox來做,界面初始化時就將表頭讀出列在listbox里。
匹配值輸入使用entry輸入框。
顯示結果也是使用listbox。
交互動作使用按鈕。
OK,視覺界面做好了,下面添加功能。
4、(字段輸入值直接獲取表頭列出選擇,找不到下拉菜單,只能用listbox來做,界面初始化時就將表頭讀出列在listbox里。)
要和mysql交互獲取,需要登錄數據庫并實現查詢。
我使用import mysql.connector模塊來實現和mysql的通訊(python還有期它模塊也能實現和mysql的通訊,當時為什么使用mysql.connector呢,我也記不清了,好像從哪個教程直接弄來用的,反正就是用了)
于是又去啃了sql的查詢語句,這里還是挺齊全的http://www.dbjr.com.cn/w3school/sql/sql_select.htm,不過我是沒學全的,沒辦法,學渣只能用到哪學到哪。重點說一下,sql語句里的 + 號就是將前后的值串起來,可以理解為and??梢詫⒆址妥兞看饋?。
5、接下來就是按鈕動作的交互代碼了,這是邏輯的重頭戲。
邏輯:在列出的字段中選擇一個要查詢的字段,輸入要匹配的值,點擊按鈕查詢,將結果顯示在顯示區(qū)。
獲取listbox的光標值,將它取出來,比對字段生成相應的sql查詢語句,和mysql交互得到返回值集,逐條取出展示在顯示區(qū)。
好了,大功告成,雖然看起來很丑,想讓它變美女就要加濾鏡咯(調tkinter格式)。
到此這篇關于python+tkinter+mysql做簡單數據庫查詢界面的文章就介紹到這了,更多相關tkinte mysql數據庫查詢界面內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
極簡Python庫CherryPy構建高性能Web應用實例探索
今天為大家介紹的是 CherryPy,它是一個極簡、穩(wěn)定且功能強大的Web框架,可以幫助開發(fā)者快速構建高性能的 Web 應用程序,使用 CherryPy,你可以輕松地創(chuàng)建RESTful API、靜態(tài)網站、異步任務和 WebSocket 等應用2024-01-01Python使用lxml模塊和Requests模塊抓取HTML頁面的教程
用Pyhton自帶的urllib或urllib2模塊抓取網頁或許有些陳詞濫調了,今天我們就來玩兒些新鮮的,來看Python使用lxml模塊和Requests模塊抓取HTML頁面的教程:2016-05-05