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

python+tkinter+mysql做簡單數(shù)據(jù)庫查詢界面

 更新時(shí)間:2022年01月11日 14:44:03   作者:方寸堂  
本文主要介紹了python+tkinter+mysql做簡單數(shù)據(jù)庫查詢界面,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

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

1、安裝mysql3.7,創(chuàng)建一個(gè)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)
#--------------------------------------------------------


#------------界面初始化時(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()
#--------------------------------------------------------

三、界面

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

四、總結(jié)

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

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

http://www.dbjr.com.cn/article/234305.htm

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

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

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

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

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

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

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

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

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

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

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

于是又去啃了sql的查詢語句,這里還是挺齊全的http://www.dbjr.com.cn/w3school/sql/sql_select.htm,不過我是沒學(xué)全的,沒辦法,學(xué)渣只能用到哪學(xué)到哪。重點(diǎn)說一下,sql語句里的 + 號(hào)就是將前后的值串起來,可以理解為and。可以將字符和變量串起來。

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

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

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

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

到此這篇關(guān)于python+tkinter+mysql做簡單數(shù)據(jù)庫查詢界面的文章就介紹到這了,更多相關(guān)tkinte mysql數(shù)據(jù)庫查詢界面內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • python光學(xué)仿真PyQt5基礎(chǔ)框架教程

    python光學(xué)仿真PyQt5基礎(chǔ)框架教程

    這篇文章主要為大家介紹了python光學(xué)仿真之PyQt5基礎(chǔ)框架教程,文中含有詳細(xì)實(shí)現(xiàn)示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2021-10-10
  • Pandas數(shù)據(jù)分析的一些常用小技巧

    Pandas數(shù)據(jù)分析的一些常用小技巧

    這篇文章主要介紹了Pandas數(shù)據(jù)分析的一些常用小技巧,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • Python3多線程爬蟲實(shí)例講解代碼

    Python3多線程爬蟲實(shí)例講解代碼

    本篇文章主要介紹了Python3多線程爬蟲實(shí)例講解代碼,Python3使用threading模塊來進(jìn)行多線程,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-01-01
  • 極簡Python庫CherryPy構(gòu)建高性能Web應(yīng)用實(shí)例探索

    極簡Python庫CherryPy構(gòu)建高性能Web應(yīng)用實(shí)例探索

    今天為大家介紹的是 CherryPy,它是一個(gè)極簡、穩(wěn)定且功能強(qiáng)大的Web框架,可以幫助開發(fā)者快速構(gòu)建高性能的 Web 應(yīng)用程序,使用 CherryPy,你可以輕松地創(chuàng)建RESTful API、靜態(tài)網(wǎng)站、異步任務(wù)和 WebSocket 等應(yīng)用
    2024-01-01
  • python使用pdfminer解析pdf文件的方法示例

    python使用pdfminer解析pdf文件的方法示例

    這篇文章主要介紹了python使用pdfminer解析pdf文件的方法示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-12-12
  • 基于tensorflow權(quán)重文件的解讀

    基于tensorflow權(quán)重文件的解讀

    這篇文章主要介紹了關(guān)于tensorflow權(quán)重文件的解讀,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。
    2021-05-05
  • Python使用lxml模塊和Requests模塊抓取HTML頁面的教程

    Python使用lxml模塊和Requests模塊抓取HTML頁面的教程

    用Pyhton自帶的urllib或urllib2模塊抓取網(wǎng)頁或許有些陳詞濫調(diào)了,今天我們就來玩兒些新鮮的,來看Python使用lxml模塊和Requests模塊抓取HTML頁面的教程:
    2016-05-05
  • Python爬取某拍短視頻

    Python爬取某拍短視頻

    現(xiàn)在短視頻可謂是一騎絕塵,吃飯的時(shí)候、休息的時(shí)候、躺在床上都在刷短視頻,今天給大家?guī)韕ython爬蟲進(jìn)階 :美拍視頻地址加密解析,需要的朋友可以參考下
    2021-06-06
  • Django高并發(fā)負(fù)載均衡實(shí)現(xiàn)原理詳解

    Django高并發(fā)負(fù)載均衡實(shí)現(xiàn)原理詳解

    這篇文章主要介紹了Django高并發(fā)負(fù)載均衡實(shí)現(xiàn)原理詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • opencv-python 提取sift特征并匹配的實(shí)例

    opencv-python 提取sift特征并匹配的實(shí)例

    今天小編就為大家分享一篇opencv-python 提取sift特征并匹配的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-12-12

最新評(píng)論