python+tkinter+mysql做简单数据库查询界面

 更新时间:2022年01月11日 14:44:03   作者:方寸堂  
本文主要介绍了python+tkinter+mysql做简单数据库查询界面,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

一、准备工作:

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',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的工具,后来发现生成的py文件对我这个菜鸟来说还是有点深奥了,而且关于page的教程全网只有一两个(无语,估计高手都不屑吧),然后就转而直接研究tkinter,以下是几个有用的链接:https://www.jb51.net/article/197751.htm?pc

https://www.jb51.net/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的查询语句,这里还是挺齐全的https://www.jb51.net/w3school/sql/sql_select.htm,不过我是没学全的,没办法,学渣只能用到哪学到哪。重点说一下,sql语句里的 + 号就是将前后的值串起来,可以理解为and。可以将字符和变量串起来。

5、接下来就是按钮动作的交互代码了,这是逻辑的重头戏。

逻辑:在列出的字段中选择一个要查询的字段,输入要匹配的值,点击按钮查询,将结果显示在显示区。

获取listbox的光标值,将它取出来,比对字段生成相应的sql查询语句,和mysql交互得到返回值集,逐条取出展示在显示区。

好了,大功告成,虽然看起来很丑,想让它变美女就要加滤镜咯(调tkinter格式)。

到此这篇关于python+tkinter+mysql做简单数据库查询界面的文章就介绍到这了,更多相关tkinte mysql数据库查询界面内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • python光学仿真PyQt5基础框架教程

    python光学仿真PyQt5基础框架教程

    这篇文章主要为大家介绍了python光学仿真之PyQt5基础框架教程,文中含有详细实现示例解析,有需要的朋友可以借鉴参考下,希望能够有所帮助
    2021-10-10
  • Pandas数据分析的一些常用小技巧

    Pandas数据分析的一些常用小技巧

    这篇文章主要介绍了Pandas数据分析的一些常用小技巧,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-02-02
  • Python3多线程爬虫实例讲解代码

    Python3多线程爬虫实例讲解代码

    本篇文章主要介绍了Python3多线程爬虫实例讲解代码,Python3使用threading模块来进行多线程,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-01-01
  • 极简Python库CherryPy构建高性能Web应用实例探索

    极简Python库CherryPy构建高性能Web应用实例探索

    今天为大家介绍的是 CherryPy,它是一个极简、稳定且功能强大的Web框架,可以帮助开发者快速构建高性能的 Web 应用程序,使用 CherryPy,你可以轻松地创建RESTful API、静态网站、异步任务和 WebSocket 等应用
    2024-01-01
  • python使用pdfminer解析pdf文件的方法示例

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

    这篇文章主要介绍了python使用pdfminer解析pdf文件的方法示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-12-12
  • 基于tensorflow权重文件的解读

    基于tensorflow权重文件的解读

    这篇文章主要介绍了关于tensorflow权重文件的解读,具有很好的参考价值,希望对大家有所帮助。
    2021-05-05
  • Python使用lxml模块和Requests模块抓取HTML页面的教程

    Python使用lxml模块和Requests模块抓取HTML页面的教程

    用Pyhton自带的urllib或urllib2模块抓取网页或许有些陈词滥调了,今天我们就来玩儿些新鲜的,来看Python使用lxml模块和Requests模块抓取HTML页面的教程:
    2016-05-05
  • Python爬取某拍短视频

    Python爬取某拍短视频

    现在短视频可谓是一骑绝尘,吃饭的时候、休息的时候、躺在床上都在刷短视频,今天给大家带来python爬虫进阶 :美拍视频地址加密解析,需要的朋友可以参考下
    2021-06-06
  • Django高并发负载均衡实现原理详解

    Django高并发负载均衡实现原理详解

    这篇文章主要介绍了Django高并发负载均衡实现原理详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-04-04
  • opencv-python 提取sift特征并匹配的实例

    opencv-python 提取sift特征并匹配的实例

    今天小编就为大家分享一篇opencv-python 提取sift特征并匹配的实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-12-12

最新评论