python制作一个简单的gui 数据库查询界面
一、准备工作:
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
3、先做好窗体部分的实现代码。
设计:按动按钮查询固定表里某一字段的某个匹配值的结果,显示在界面中。
元件:输入元件2个(1个字段,1个值),结果显示元件1个,按钮1个。
字段输入值直接获取表头列出选择,找不到下拉菜单,只能用listbox来做,界面初始化时就将表头读出列在listbox里。
匹配值输入使用entry输入框。
显示结果也是使用listbox。
交互动作使用按钮。
ok,视觉界面做好了,下面添加功能。
4、(字段输入值直接获取表头列出选择,找不到下拉菜单,只能用listbox来做,界面初始化时就将表头读出列在listbox里。)
要和mysql交互获取,需要登录数据库并实现查询。
我使用import mysql.connector模块来实现和mysql的通讯(python还有期它模块也能实现和mysql的通讯,当时为什么使用mysql.connector呢,我也记不清了,好像从哪个教程直接弄来用的,反正就是用了)
于是又去啃了sql的查询语句,这里还是挺齐全的,不过我是没学全的,没办法,学渣只能用到哪学到哪。重点说一下,sql语句里的 + 号就是将前后的值串起来,可以理解为and。可以将字符和变量串起来。
5、接下来就是按钮动作的交互代码了,这是逻辑的重头戏。
逻辑:在列出的字段中选择一个要查询的字段,输入要匹配的值,点击按钮查询,将结果显示在显示区。
获取listbox的光标值,将它取出来,比对字段生成相应的sql查询语句,和mysql交互得到返回值集,逐条取出展示在显示区。
好了,大功告成,虽然看起来很丑,想让它变美女就要加滤镜咯(调tkinter格式)。
以上就是python制作一个简单的gui 数据库查询界面的详细内容,更多关于python gui数据库查询的资料请关注其它相关文章!
推荐阅读
-
利用html来制作一个简单美观的购物车界面
-
Python利用PyQt5制作一个获取网络实时NBA数据并播报的GUI程序
-
使用Python中tkinter库简单gui界面制作及打包成exe的操作方法(二)
-
python 制作一个gui界面的翻译工具
-
python 实现简单的计算器(gui界面)
-
Python3 网易有道词典结合PyInstaller,tkinter制作一个简单的中英文翻译exe文件
-
python实现简单的井字棋游戏(gui界面)
-
基于Python3制作一个带GUI界面的小说爬虫工具
-
python制作一个简单的gui 数据库查询界面
-
如果打算亲手制作一个简单的python解释器需要掌握哪些知识?