菜鸟试做GUI简单数据库查询界面 python+tkinter+mysql
一、准备工作:
1、安装mysql3.7,创建一个test数据库,创建student表,创建列:(列名看代码),创建几条数据
(以上工作直接用navicat for mysql工具完成)
二、代码:
1 import sys
2 import tkinter as tk
3 import mysql.connector as sql
4
5 #--------------------查询函数---------------------------
6 def sql_connect():
7 listbox_show.delete(0,'end') #初始化清空显示区
8 m = listbox_name.curselection()[0]
9 print('m=',m)
10 list_name = listbox_name.get(m)[0]
11 varlue = entry_varlue.get()
12 print('list_name=',list_name)
13 print('var=',varlue)
14
15 while list_name == 'Student_ID':
16 sql_sr = "select * from Student where student.student_id = " + "'" + varlue +"'"
17 print(sql_sr)
18 break
19 while list_name == 'Name':
20 sql_sr = "select * from Student where student.name = " + "'" + varlue +"'"
21 print(sql_sr)
22 break
23
24 while list_name == 'Age':
25 sql_sr = "select * from Student where student.age = " + "'" + varlue +"'"
26 print(sql_sr)
27 break
28 while list_name == 'Sex':
29 sql_sr = "select * from Student where student.sex = " + "'" + varlue +"'"
30 print(sql_sr)
31 break
32 while list_name == 'Class':
33 sql_sr = "select * from Student where student.class = " + "'" + varlue +"'"
34 print(sql_sr)
35 break
36
37 mydb = sql.connect(host='localhost',user='root',passwd='123456',database='test')
38 mycursor = mydb.cursor()
39 mycursor.execute(sql_sr)
40 myresult = mycursor.fetchall()
41 for x in myresult:
42 print (x)
43 listbox_show.insert('end',x)
44 #--------------------------------------------------------
45
46
47 #------------界面初始化时加载选项列表--------------------
48 sql_n = "SELECT COLUMN_NAME FROM information_schema.COLUMNS \
49 WHERE TABLE_SCHEMA = 'test' AND TABLE_NAME = 'student'"
50 mydb = sql.connect(host='localhost',user='root',passwd='123456',database='test')
51 mycursor = mydb.cursor()
52 mycursor.execute(sql_n)
53 myresult = mycursor.fetchall()
54
55 #--------------------------------------------------------
56
57 #----------窗体部分--------------------------------------
58 entry_list_name = tk.Entry()
59 entry_list_name.pack()
60
61 listbox_name = tk.Listbox()
62 listbox_name.pack()
63 for i in myresult:
64 listbox_name.insert('end',i) #加载选项列表
65
66 entry_varlue = tk.Entry()
67 entry_varlue.pack()
68
69 button_select = tk.Button(text = '查找',command = sql_connect)
70 button_select.pack()
71
72 listbox_show = tk.Listbox()
73 listbox_show.pack()
74
75
76 root.mainloop()
77 #--------------------------------------------------------
78
三、界面

好吧,是挺丑的,因为没调格式,将就吧。
四、总结
1、目的:自己这个菜鸟新手天天看基础教程觉得很抽象,各种运算结果只能打印在IDE窗口,不是我想象中的程序(有界面,有交互,有。。。总之很精彩),然后按教程的各种渐进学法感觉不太适合自己的风格,我喜欢有一个具体的东西,不断的添加功能,然后在添加的过程中碰到问题再寻求解决办法,在解决的过程中学习新知识,嗯,就是只学能用到的,很功利。。。然后就开始折腾这个小界面。
2、首先要有GUI界面就要用到GUI模块,本着方便原则就用python自带的tkinter(不用再折腾安装),一开始我想用所见即所得的方式,找到了一个可以拖放元件来生成界面的工具page python,这也是个基于tkinter的工具,后来发现生成的py文件对我这个菜鸟来说还是有点深奥了,而且关于page的教程全网只有一两个(无语,估计高手都不屑吧),然后就转而直接研究tkinter,以下是几个有用的链接:https://www.cnblogs.com/shwee/p/9427975.html
https://blog.csdn.net/qq_41556318/article/details/85108351
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格式)。
菜鸟试做GUI简单数据库查询界面 python+tkinter+mysql的更多相关文章
- sencha做个简单的登录界面
很多人都在群里问要一个好看的登录界面,我表示很无奈,哪有好看的,每个人的要求不一样,要好看的只有自己做. 下面是我自己整理的一个通用版的登录界面,稍做修改,很容易能变成你想要的界面, 不说废话,直接上 ...
- Python --链接MYSQL数据库与简单操作 含SSH链接
项目是软硬件结合,在缺少设备的情况,需要通过接口来模拟实现与设备的交互,其中就需要通过从数据库读取商品的ID信息 出于安全考虑 现在很多数据库都不允许通过直接访问,大多数是通过SSH SSH : 数 ...
- tkinter做一个简单的登陆页面
做一个简单的登陆页面 import tkinter wuya = tkinter.Tk() wuya.title("wuya") wuya.geometry("900x3 ...
- tkinter做一个简单的登陆页面(十六)
做一个简单的登陆页面 import tkinter wuya = tkinter.Tk() wuya.title("wuya") wuya.geometry("900x3 ...
- 数据库查询操作(fetchone,fetchall)
数据库查询操作 Python查询Mysql使用 fetchone() 方法获取单条数据, 使用fetchall() 方法获取多条数据. fetchone(): 该方法获取下一个查询结果集.结果集是一个 ...
- python接口自动化(三十八)-python操作mysql数据库(详解)
简介 现在的招聘要求对QA人员的要求越来越高,测试的一些基础知识就不必说了,来说测试知识以外的,会不会一门或者多门开发与语言,能不能读懂代码,会不会Linux,会不会搭建测试系统,会不会常用的数据库, ...
- 使用Python对MySQL数据库操作
本文介绍Python3使用PyMySQL连接数据库,并实现简单的增删改查. 什么是PyMySQL? PyMySQL是Python3.x版本中用于连接MySQL服务器的一个库,Python2.x中则使用 ...
- Python学习(21)python操作mysql数据库_操作
目录 数据库连接 创建数据库表 数据库插入操作 数据库查询操作 数据库更新操作 删除操作 执行事务 错误处理 数据库连接 连接数据库前,请先确认以下事项: 您已经创建了数据库 TEST. 在TEST数 ...
- python操作mysql数据库实现增删改查
Python 标准数据库接口为 Python DB-API,Python DB-API为开发人员提供了数据库应用编程接口. Python 数据库接口支持非常多的数据库,你可以选择适合你项目的数据库: ...
随机推荐
- 阅读-Calibre Library转PDF、EPUB配置
提示:如果想恢复默认设置,点击"恢复默认值"即可 -----EPUB (MOBI同理)----- 目标:解决转换过程中图片清晰度丢失问题(分辨率太低) 右击-转换书籍-逐个转换 输 ...
- 想买保时捷的运维李先生学Java性能之 JIT即时编译器
前言 本文记录日常学习<深入理解Java虚拟机>,不知道为啥感觉看一遍也就过了,喜欢动动手理解理解,这样才有点感觉,静不下心来的时候,看书抄书也可以用这个办法. 一.什么是JIT(Just ...
- HashMap循环中Remove带来的问题
HashMap在循环中执行remove操作会报错,引发了并发修改异常. 解决办法很多: 1.复制一个Map,在Map副本中循环,Map本体执行remove方法. 2.使用迭代器移除当前迭代元素,ite ...
- update不能直接使用select的返回结果
update不能直接使用select的返回结果,这是会报错的,这是SQL的语法规定的,若想在update中与select结合使用,sql需要这样写: 1.其中field1,field2为表中的字段名 ...
- axb_2019_heap-format_string + off-by-one
axb_2019_heap 简单题,格式化字符串泄漏栈地址 算上rsp,格式化字符串参数是栈顺序+6-1 edit有off by one 构造unlink chunk0 chunk1 chunk2 构 ...
- Windows定时任务copy到nfs目录
@echo off mount 192.168.5.10:/data/test x: xcopy /y "D:\backup\mysql\20200316_230000.sql.tar.gz ...
- leo101
tags: 贪心 date: 2019-4-4 jag2017autumnJ Farm Village 题面 题目链接 翻译 数轴上有 n 个村庄,每个村庄可以生产两个单位的粮食.在每个村庄生产一单位 ...
- 4G DTU的使用方法和应用领域
4G DTU是一种数据传输单元,通俗理解就是,用来传输数据的一种硬件.既然是用来传输数据的,那就能将它视为一个管道,也就是说,指令同过它传给设备,而管道是不对这些指令做出响应的. 4G DTU如何使用 ...
- 部署LNMP环境
1.安装nginx yum -y install gcc pcre-devel openssl-devel tar xf nginx-1.16.1.tar.gz cd nginx-1.16.1/ ./ ...
- 删除指定路径下指定天数之前(以文件的修改日期为准)的文件:forfiles
删除指定路径下指定天数之前(以文件的修改日期为准)的文件:forfiles 代码如下: @echo off ::演示:删除指定路径下指定天数之前(以文件的最后修改日期为准)的文件. ::如果演示结果无 ...