欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

python制作一個簡單的gui 數(shù)據(jù)庫查詢界面

 更新時間:2020年11月19日 14:10:50   作者:方寸堂  
這篇文章主要介紹了python制作一個簡單的gui 數(shù)據(jù)庫查詢界面,幫助大家更好的理解和學習python tkinter的使用,感興趣的朋友可以了解下

一、準備工作:

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

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

二、代碼:

import sys
import tkinter as tk
import 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)
#--------------------------------------------------------


#------------界面初始化時加載選項列表--------------------
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()
#--------------------------------------------------------

三、界面

 好吧,是挺丑的,因為沒調(diào)格式,將就吧。

四、總結

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

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

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

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

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

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

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

顯示結果也是使用listbox。

交互動作使用按鈕。

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

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

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

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

于是又去啃了sql的查詢語句,這里還是挺齊全的https://www.runoob.com/sql/sql-select.html,不過我是沒學全的,沒辦法,學渣只能用到哪學到哪。重點說一下,sql語句里的 + 號就是將前后的值串起來,可以理解為and??梢詫⒆址妥兞看饋?。

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

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

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

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

以上就是python制作一個簡單的gui 數(shù)據(jù)庫查詢界面的詳細內(nèi)容,更多關于python gui數(shù)據(jù)庫查詢的資料請關注腳本之家其它相關文章!

相關文章

  • 解決Django中調(diào)用keras的模型出現(xiàn)的問題

    解決Django中調(diào)用keras的模型出現(xiàn)的問題

    今天小編就為大家分享一篇解決Django中調(diào)用keras的模型出現(xiàn)的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-08-08
  • python可視化分析繪制散點圖和邊界氣泡圖

    python可視化分析繪制散點圖和邊界氣泡圖

    這篇文章主要介紹了python可視化分析繪制散點圖和邊界氣泡圖,python繪制散點圖,展現(xiàn)兩個變量間的關系,當數(shù)據(jù)包含多組時,使用不同顏色和形狀區(qū)分
    2022-06-06
  • Python二叉搜索樹與雙向鏈表轉(zhuǎn)換實現(xiàn)方法

    Python二叉搜索樹與雙向鏈表轉(zhuǎn)換實現(xiàn)方法

    這篇文章主要介紹了Python二叉搜索樹與雙向鏈表轉(zhuǎn)換實現(xiàn)方法,涉及Python二叉搜索樹的定義、實現(xiàn)以及雙向鏈表的轉(zhuǎn)換技巧,需要的朋友可以參考下
    2016-04-04
  • Python3將jpg轉(zhuǎn)為pdf文件的方法示例

    Python3將jpg轉(zhuǎn)為pdf文件的方法示例

    這篇文章主要介紹了Python3將jpg轉(zhuǎn)為pdf文件的方法,結合完整實例形式分析了Python3針對jpg轉(zhuǎn)pdf格式的文件讀寫、編碼裝換等相關操作技巧,需要的朋友可以參考下
    2019-12-12
  • python腳本執(zhí)行CMD命令并返回結果的例子

    python腳本執(zhí)行CMD命令并返回結果的例子

    今天小編就為大家分享一篇python腳本執(zhí)行CMD命令并返回結果的例子,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-08-08
  • python判斷輸入日期為第幾天的實例

    python判斷輸入日期為第幾天的實例

    今天小編就為大家分享一篇python判斷輸入日期為第幾天的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-11-11
  • Python實現(xiàn)的NN神經(jīng)網(wǎng)絡算法完整示例

    Python實現(xiàn)的NN神經(jīng)網(wǎng)絡算法完整示例

    這篇文章主要介紹了Python實現(xiàn)的NN神經(jīng)網(wǎng)絡算法,結合完整實例形式分析了Python使用numpy、matplotlib及sklearn模塊實現(xiàn)NN神經(jīng)網(wǎng)絡相關算法實現(xiàn)技巧與操作注意事項,需要的朋友可以參考下
    2018-06-06
  • el-table 多表格彈窗嵌套數(shù)據(jù)顯示異常錯亂問題解決方案

    el-table 多表格彈窗嵌套數(shù)據(jù)顯示異常錯亂問題解決方案

    使用vue+element開發(fā)報表功能時,需要列表上某列的超鏈接按鈕彈窗展示,在彈窗的el-table列表某列中再次使用超鏈接按鈕點開彈窗,以此類推多表格彈窗嵌套,本文以彈窗兩次為例,需要的朋友可以參考下
    2023-11-11
  • python中*args與**kwarsg及閉包和裝飾器的用法

    python中*args與**kwarsg及閉包和裝飾器的用法

    這篇文章主要介紹了python中*args與**kwarsg及閉包和裝飾器的用法說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • Python極簡代碼實現(xiàn)楊輝三角示例代碼

    Python極簡代碼實現(xiàn)楊輝三角示例代碼

    楊輝三角形因為其形式簡單,又有一定的使用價值,因此是入門編程題中被用的最多的,也是很好的語言實例標的。這篇文章就給大家介紹了Python極簡代碼實現(xiàn)楊輝三角的方法,文章給出了詳細的示例代碼和解釋,對大家理解很有幫助,感興趣的朋友們下面來一起看看吧。
    2016-11-11

最新評論