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的查询语句,这里还是挺齐全的https://www.runoob.com/sql/sql-select.html,不过我是没学全的,没办法,学渣只能用到哪学到哪。重点说一下,sql语句里的 + 号就是将前后的值串起来,可以理解为and。可以将字符和变量串起来。

5、接下来就是按钮动作的交互代码了,这是逻辑的重头戏。

逻辑:在列出的字段中选择一个要查询的字段,输入要匹配的值,点击按钮查询,将结果显示在显示区。

获取listbox的光标值,将它取出来,比对字段生成相应的sql查询语句,和mysql交互得到返回值集,逐条取出展示在显示区。

好了,大功告成,虽然看起来很丑,想让它变美女就要加滤镜咯(调tkinter格式)。

以上就是python制作一个简单的gui 数据库查询界面的详细内容,更多关于python gui数据库查询的资料请关注我们其它相关文章!

(0)

相关推荐

  • Python的Django框架实现数据库查询(不返回QuerySet的方法)

    一.创建模型类: # -*- coding: utf-8 -*- from __future__ import unicode_literals from django.db import models class Course(models.Model): """课程表""" name = models.CharField(verbose_name='课程名称', max_length=255) description = models.Tex

  • Python实现的查询mysql数据库并通过邮件发送信息功能

    本文实例讲述了Python实现的查询mysql数据库并通过邮件发送信息功能.分享给大家供大家参考,具体如下: 这里使用Python查询mysql数据库,并通过邮件发送宕机信息. Python代码如下: #-*- coding: UTF-8 -*- #!/usr/bin/env python ''''' author:qlzhong Created on 2015-6-29 征途宕机日志统计汇总 ''' import MySQLdb import time import datetime impo

  • python针对mysql数据库的连接、查询、更新、删除操作示例

    本文实例讲述了python针对mysql数据库的连接.查询.更新.删除操作.分享给大家供大家参考,具体如下: 连接 一 代码 import pymysql # 打开数据库连接 db = pymysql.connect("localhost","root","root","db_test01" ) # 使用 cursor() 方法创建一个游标对象 cursor cursor = db.cursor() # 使用 execute(

  • Python编写通讯录通过数据库存储实现模糊查询功能

    1.要求 数据库存储通讯录,要求按姓名/电话号码查询,查询条件只有一个输入入口,自动识别输入的是姓名还是号码,允许模糊查询. 2.实现功能 可通过输入指令进行操作. (1)首先输入"add",可以对通讯录进行添加联系人信息. sql1 = 'insert into TA(ID,NAME,AGE,ADDRESS,TELENUMBER)' sql1 += 'values("%d","%s","%d","%s",

  • Python flask框架实现查询数据库并显示数据

    首先数据库长这样 我们想将name和age列显示到web页面 上代码sqlshowweb.py from flask import Flask from flask import render_template import pymysql app = Flask(__name__) @app.route('/') def index(): conn = pymysql.connect(host='39.106.168.84', user='flask_topvj_net', password=

  • python中数据库like模糊查询方式

    在Python中%是一个格式化字符,所以如果需要使用%则需要写成%%. 将在Python中执行的sql语句改为: sql = "SELECT * FROM table_test WHERE value LIKE '%%%%%s%%%%'" % test_value 执行成功,print出SQL语句之后为: SELECT * FROM table_test WHERE value LIKE '%%public%%' Python在执行sql语句的时候,同样也会有%格式化的问题,仍然需要使

  • 跟老齐学Python之使用Python查询更新数据库

    回顾一下已有的战果:(1)连接数据库;(2)建立指针:(3)通过指针插入记录:(4)提交将插入结果保存到数据库.在交互模式中,先温故,再知新. 复制代码 代码如下: >>> #导入模块 >>> import MySQLdb >>> #连接数据库 >>> conn = MySQLdb.connect(host="localhost",user="root",passwd="123123&

  • python pymysql链接数据库查询结果转为Dataframe实例

    我就废话不多说了,大家还是直接看代码吧! import pymysql import pandas as pd def con_sql(db,sql): # 创建连接 db = pymysql.connect(host='127.0.0.1', port=3308, user='name', passwd='password', db=db, charset='utf8') # 创建游标 cursor = db.cursor() cursor.execute(sql) result = curs

  • Python操作mongodb数据库进行模糊查询操作示例

    本文实例讲述了Python操作mongodb数据库进行模糊查询操作.分享给大家供大家参考,具体如下: # -*- coding: utf-8 -*- import pymongo import re from pymongo import MongoClient #创建连接 #10.20.66.106 client = MongoClient('10.20.4.79', 27017) #client = MongoClient('10.20.66.106', 27017) db_name = '

  • python使用多线程查询数据库的实现示例

    一.背景: 当数据量过大时,一个程序的执行时间就会主要花费在等待单次查询返回结果,在这个过程中cpu无疑是处于等待io的空闲状态的,这样既浪费了cpu资源,又花费了大量时间(当然这里主要说多线程,批量查询不在考虑范围,总会存在不能批量查询的情况),在这种非密集型运算(及大量占用cpu资源)的情况下在python中无疑运用多线程是一个非常棒的选择. 二.知识点: 数据库连接池的运用及优势,python中多线程的运用,队列的运用 数据库连接池:限制了数据库的连接最大个数,每次连接都是可以重复使用的,

  • Python 操作mysql数据库查询之fetchone(), fetchmany(), fetchall()用法示例

    本文实例讲述了Python 操作mysql数据库查询之fetchone(), fetchmany(), fetchall()用法.分享给大家供大家参考,具体如下: demo.py(查询,取出一条数据,fetchone): from pymysql import * def main(): # 创建Connection连接 conn = connect(host='localhost',port=3306,user='root',password='mysql',database='jing_do

随机推荐