python+tkinter+mysql做简单数据库查询界面
作者:方寸堂 发布时间:2024-01-19 21:13:20
一、准备工作:
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交互得到返回值集,逐条取出展示在显示区。
来源:https://www.cnblogs.com/fct-notebook/p/13883925.html


猜你喜欢
- SAX将dd.xml解析成html。当然啦,如果得到了xml对应的xsl文件可以直接用libxml2将其转换成html。#!/usr/bin
- 1.直接使用dlib安装dlib方法:Win10安装dlib GPU过程详解思路:1、使用dlib.get_frontal_fac
- 每次在操作数据库的时候最烦的就是根据表单提交的内容写sql语句,特别是字段比较多的时候很麻烦,动不动就容易写错。所以我就写了下面的生成sql
- 目录Python1 Python垃圾回收机制是什么2 元组和列表的区别3 元组可以作为字典的key?4 进程 线程 协程4.1 进程4.2
- 一、shutil模块(了解):高级的文件、文件夹、压缩包处理模块。import shutil# shutil.copyfileobj(fsr
- 第一种方法:select *from ( select Url,case when Month=01 then&nb
- 第一次发博客,还有点小激动,本人现在正在天津上大学,希望以后从事前端这一行业,学习的时间不长,写博客为了记录自己的学习过程和收获,当然也算是
- 方法一,利用 sheet.iter_rows() 获取 Sheet1 表中的所有行,然后遍历import openpyxl wb = ope
- 小编想把用python将列表[1,1,1,1,1,1,1,1,1,1] 和 列表 [2,2,2,2,2,2,2,2,2,2]对应相加成[3,
- 如下所示:import wuhan.wuhan11class Han: def __init__(self, config):
- SQL Server 2005开始,我们可以直接通过CTE来支持递归查询,CTE即公用表表达式公用表表达式(CTE),是一个在查询中定义的临
- 本文实例讲述了python threading和multiprocessing模块基本用法。分享给大家供大家参考,具体如下:前言这两天为了做
- 我们可以把表里每一个横行的数据,看成是不同的元组。在理解了这个概念后,昨天我们学了不少的namedtuple类,是否也能把元组转换成name
- SQLSRV驱动程序允许您创建一个结果集,其中包含可以根据游标类型以任何顺序访问的行。本主题将讨论客户端(缓冲)和服务器端(非缓冲)游标及其
- 最近看到了两行 JavaScript 代码,很受启发。1. 封装 DOM 属性在 JavaScript 中,我们可以获取HTML元素的属性值
- 本文实例为大家分享了python统计序列中元素的具体代码,供大家参考,具体内容如下问题1: &
- 说明:通过随机产生密码,然后将密码EMail给注册用户,你可以确认用户的EMail填写是否正确。自动产生的密码往往安全性更高,同时,你可以过
- python一行输入n个数据有时会碰到一行输入多个数据,这是可以先用str类型存一组数据,然后再迭代的将每个数据追加到新的列表中。方法一先输
- 简介困扰在 Python 中使用并发编程来提高效率对于数据科学家来说并不罕见。在后台观察各种子进程或并发线程以保持我的计算或 IO 绑定任务
- Ctrl+N 按文件名搜索py文件ctrl+n可以搜索py文件勾选上面这个框可以搜索工程以外的文件Ctrl+shift+N 按文件名搜索所有