• 菜鸟试做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格式)。

  • 相关阅读:
    二分查找binarySearch
    快速排序quicksort实现方法
    读书清单
    windows 下遍历文件夹
    如何输出 android.mk 及 Application.mk 中个变量的值
    【转】 armeabi与armeabi-v7a
    Application.mk
    【转】TypeError: 'module' object is not callable 原因分析
    User breakpoint called from code at XXX的解决方式记录
    关于溢出的一些体会
  • 原文地址:https://www.cnblogs.com/fct-notebook/p/13883925.html
Copyright © 2020-2023  润新知