菜鳥試做GUI簡單數據庫查詢界面 python+tkinter+mysql


一、准備工作:

1、安裝mysql3.7,創建一個test數據庫,創建student表,創建列:(列名看代碼),創建幾條數據

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

二、代碼:

 1 import sys
 2 import tkinter as tk
 3 import mysql.connector as sql
 4 
 5 #--------------------查詢函數---------------------------
 6 def sql_connect():
 7     listbox_show.delete(0,'end') #初始化清空顯示區
 8     m = listbox_name.curselection()[0]
 9     print('m=',m)
10     list_name = listbox_name.get(m)[0]
11     varlue = entry_varlue.get()
12     print('list_name=',list_name)
13     print('var=',varlue)
14     
15     while list_name == 'Student_ID':
16         sql_sr = "select * from Student where student.student_id = " + "'" + varlue +"'"
17         print(sql_sr)
18         break
19     while list_name == 'Name':
20         sql_sr = "select * from Student where student.name = " + "'" + varlue +"'"
21         print(sql_sr)
22         break
23 
24     while list_name == 'Age':
25         sql_sr = "select * from Student where student.age = " + "'" + varlue +"'"
26         print(sql_sr)
27         break
28     while list_name == 'Sex':
29         sql_sr = "select * from Student where student.sex = " + "'" + varlue +"'"
30         print(sql_sr)
31         break
32     while list_name == 'Class':
33         sql_sr = "select * from Student where student.class = " + "'" + varlue +"'"
34         print(sql_sr)
35         break
36         
37     mydb = sql.connect(host='localhost',user='root',passwd='123456',database='test')
38     mycursor = mydb.cursor()
39     mycursor.execute(sql_sr)
40     myresult = mycursor.fetchall()
41     for x in myresult:
42         print (x)
43         listbox_show.insert('end',x)
44 #--------------------------------------------------------
45         
46 
47 #------------界面初始化時加載選項列表--------------------
48 sql_n = "SELECT COLUMN_NAME FROM information_schema.COLUMNS \
49 WHERE TABLE_SCHEMA = 'test' AND TABLE_NAME = 'student'"
50 mydb = sql.connect(host='localhost',user='root',passwd='123456',database='test')
51 mycursor = mydb.cursor()
52 mycursor.execute(sql_n)
53 myresult = mycursor.fetchall()
54 
55 #--------------------------------------------------------
56 
57 #----------窗體部分--------------------------------------
58 entry_list_name = tk.Entry()
59 entry_list_name.pack()
60 
61 listbox_name = tk.Listbox()
62 listbox_name.pack()
63 for i in myresult:
64     listbox_name.insert('end',i) #加載選項列表
65     
66 entry_varlue = tk.Entry()
67 entry_varlue.pack()
68 
69 button_select = tk.Button(text = '查找',command = sql_connect)
70 button_select.pack()
71 
72 listbox_show = tk.Listbox()
73 listbox_show.pack()
74 
75 
76 root.mainloop()
77 #--------------------------------------------------------
78    

三、界面

 

 好吧,是挺丑的,因為沒調格式,將就吧。

四、總結

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

2、首先要有GUI界面就要用到GUI模塊,本着方便原則就用python自帶的tkinter(不用再折騰安裝),一開始我想用所見即所得的方式,找到了一個可以拖放元件來生成界面的工具page python,這也是個基於tkinter的工具,后來發現生成的py文件對我這個菜鳥來說還是有點深奧了,而且關於page的教程全網只有一兩個(無語,估計高手都不屑吧),然后就轉而直接研究tkinter,以下是幾個有用的鏈接:https://www.cnblogs.com/shwee/p/9427975.html

https://blog.csdn.net/qq_41556318/article/details/85108351

3、先做好窗體部分的實現代碼。

設計:按動按鈕查詢固定表里某一字段的某個匹配值的結果,顯示在界面中。

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

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

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

顯示結果也是使用listbox。

交互動作使用按鈕。

OK,視覺界面做好了,下面添加功能。

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

要和mysql交互獲取,需要登錄數據庫並實現查詢。

我使用import mysql.connector模塊來實現和mysql的通訊(python還有期它模塊也能實現和mysql的通訊,當時為什么使用mysql.connector呢,我也記不清了,好像從哪個教程直接弄來用的,反正就是用了)

於是又去啃了sql的查詢語句,這里還是挺齊全的https://www.runoob.com/sql/sql-select.html,不過我是沒學全的,沒辦法,學渣只能用到哪學到哪。重點說一下,sql語句里的 + 號就是將前后的值串起來,可以理解為and。可以將字符和變量串起來。

5、接下來就是按鈕動作的交互代碼了,這是邏輯的重頭戲。

邏輯:在列出的字段中選擇一個要查詢的字段,輸入要匹配的值,點擊按鈕查詢,將結果顯示在顯示區。

獲取listbox的光標值,將它取出來,比對字段生成相應的sql查詢語句,和mysql交互得到返回值集,逐條取出展示在顯示區。

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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM