1. 程式人生 > 程式設計 >python製作一個簡單的gui 資料庫查詢介面

python製作一個簡單的gui 資料庫查詢介面

一、準備工作:

1、安裝mysql3.7,建立一個test資料庫,建立student表,建立列:(列名看程式碼),建立幾條資料

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

二、程式碼:

import sys
import tkinter as tk
import mysql.connector as sql

#--------------------查詢函式---------------------------
def sql_connect():
  listbox_show.delete(0,'end') #初始化清空顯示區
  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',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()
#--------------------------------------------------------

三、介面

python製作一個簡單的gui 資料庫查詢介面

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

四、總結

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

2、首先要有GUI介面就要用到GUI模組,本著方便原則就用python自帶的tkinter(不用再折騰安裝),一開始我想用所見即所得的方式,找到了一個可以拖放元件來生成介面的工具page python,這也是個基於tkinter的工具,後來發現生成的py檔案對我這個菜鳥來說還是有點深奧了,而且關於page的教程全網只有一兩個(無語,估計高手都不屑吧),然後就轉而直接研究tkinter

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格式)。

以上就是python製作一個簡單的gui 資料庫查詢介面的詳細內容,更多關於python gui資料庫查詢的資料請關注我們其它相關文章!