python制作一个简单的gui 数据库查询界面


Posted in Python onNovember 19, 2020

一、准备工作:

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()
#--------------------------------------------------------

三、界面

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数据库查询的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
Python标准库之Sys模块使用详解
May 23 Python
详解Python中的日志模块logging
Jun 19 Python
深入解析Python中的lambda表达式的用法
Aug 28 Python
Ruby元编程基础学习笔记整理
Jul 02 Python
Python循环语句中else的用法总结
Sep 11 Python
Python读csv文件去掉一列后再写入新的文件实例
Dec 28 Python
利用Python+阿里云实现DDNS动态域名解析的方法
Apr 01 Python
python使用requests模块实现爬取电影天堂最新电影信息
Apr 03 Python
python爬虫 猫眼电影和电影天堂数据csv和mysql存储过程解析
Sep 05 Python
python 画3维轨迹图并进行比较的实例
Dec 06 Python
Python爬虫防封ip的一些技巧
Aug 06 Python
图文详解matlab原始处理图像几何变换
Jul 09 Python
解决python3中os.popen()出错的问题
Nov 19 #Python
Python中return函数返回值实例用法
Nov 19 #Python
python 三种方法实现对Excel表格的读写
Nov 19 #Python
基于python模拟bfs和dfs代码实例
Nov 19 #Python
Python 多进程、多线程效率对比
Nov 19 #Python
Python导入父文件夹中模块并读取当前文件夹内的资源
Nov 19 #Python
Pytorch实验常用代码段汇总
Nov 19 #Python
You might like
php实现根据IP地址获取其所在省市的方法
2015/04/30 PHP
php基于curl重写file_get_contents函数实例
2016/11/08 PHP
PHP随机生成中文段落示例【测试网站内容时使用】
2020/04/26 PHP
ThinkPHP5.1验证码功能实现的示例代码
2020/06/08 PHP
使用prototype.js 的时候应该特别注意的几个问题.
2007/04/12 Javascript
js实现带搜索功能的下拉框实时搜索实时匹配
2013/11/05 Javascript
node.js实现BigPipe详解
2014/12/05 Javascript
JavaScript获得表单target属性的方法
2015/04/02 Javascript
jquery SweetAlert插件实现响应式提示框
2015/08/18 Javascript
JavaScript基于自定义函数判断变量类型的实现方法
2016/11/23 Javascript
uploader秒传图片到服务器完整代码
2017/04/22 Javascript
浅谈vue中慎用style的scoped属性
2017/11/28 Javascript
如何使用puppet替换文件中的string
2018/12/06 Javascript
Vue混入mixins滚动触底的方法
2019/11/22 Javascript
js实现滑动滑块验证登录
2020/07/24 Javascript
使用webpack和rollup打包组件库的方法
2021/02/25 Javascript
[01:28:24]NAVI vs VG Supermajor 败者组 BO3 第三场 6.5
2018/06/06 DOTA
一篇文章入门Python生态系统(Python新手入门指导)
2015/12/11 Python
matplotlib savefig 保存图片大小的实例
2018/05/24 Python
python实现维吉尼亚加密法
2019/03/20 Python
python实现kmp算法的实例代码
2019/04/03 Python
python中设置超时跳过,超时退出的方式
2019/12/13 Python
Python unittest基本使用方法代码实例
2020/06/29 Python
如何利用python正则表达式匹配版本信息
2020/12/09 Python
VSCode中autopep8无法运行问题解决方案(提示Error: Command failed,usage)
2021/03/02 Python
浅谈CSS3特性查询(Feature Query: @supports)功能简介
2017/07/31 HTML / CSS
ESDlife健康生活易:身体检查预订、搜寻及比较
2019/05/10 全球购物
倩碧澳大利亚官网:Clinique澳大利亚
2019/07/22 全球购物
制药工程专业毕业生推荐信
2013/12/24 职场文书
校运会广播稿100字
2014/01/27 职场文书
行政人事岗位职责
2014/03/17 职场文书
另类冲刺标语
2014/06/24 职场文书
意外伤害赔偿协议书
2014/09/16 职场文书
个人买房协议书范本
2014/10/06 职场文书
教师查摆问题及整改措施
2014/10/11 职场文书
文明家庭事迹材料
2014/12/20 职场文书