IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> Python学生管理系统+MySQL+tkinter+pyinstaller(终章) -> 正文阅读

[大数据]Python学生管理系统+MySQL+tkinter+pyinstaller(终章)

终极版终于有时间给大家分享了!!!。

?我们先看一下效果图。

1:登录界面:

2:

查询数据库所有的内容!

?

3:

链接数据库:

?

?4:最终的打包!

话不多说直接上代码!!!!?

from tkinter import *
import pymysql
from tkinter.messagebox import *
from tkinter import ttk

def get_connect():
    conn = pymysql.connect(host='localhost', user="root", passwd='GAO147258369',database='stu')
    return conn


root = Tk()
root.geometry('700x800')
root.title('学生管理系统')

Label(root, text="学号:").place(relx=0, rely=0.05, relwidth=0.1)
Label(root, text="姓名:").place(relx=0.5, rely=0.05, relwidth=0.1)
Label(root, text="性别:").place(relx=0, rely=0.1, relwidth=0.1)
Label(root, text="电话:").place(relx=0.5, rely=0.1, relwidth=0.1)

sid1 = StringVar()
name1 = StringVar()
sex1 = StringVar()
phone = StringVar()
Entry(root, textvariable=sid1).place(relx=0.1, rely=0.05, relwidth=0.37, height=25)
Entry(root, textvariable=name1).place(relx=0.6, rely=0.05, relwidth=0.37, height=25)

Entry(root, textvariable=sex1).place(relx=0.1, rely=0.1, relwidth=0.37, height=25)
Entry(root, textvariable=phone).place(relx=0.6, rely=0.1, relwidth=0.37, height=25)

def add():
    list1 =[]
    list1.append(sid1.get())
    list1.append(name1.get())
    list1.append(sex1.get())
    list1.append(phone.get())
    # print(list1)
    connection = get_connect()
    cur = connection.cursor(cursor=pymysql.cursors.DictCursor)
    sql = 'insert into student(学号,姓名,性别,电话) values("%s","%s","%s", "%s")'
    sid = int(list1[0])
    name = list1[1]
    sex = list1[2]
    iphone = int(list1[3])
    try:
        cur.execute(sql % (sid, name, sex, iphone))
        connection.commit()
    except Exception as e:
        connection.rollback()
        raise e
    finally:
        connection.close()
    showinfo('提示','添加成功!')




def search():
    showinfo('提示','请输入学号!')
    into = int(sid1.get())
    conn = pymysql.connect(host='localhost', user="root", passwd="GAO147258369", database='stu')
    cur = conn.cursor()
    sql = 'select * from student ;'
    cur.execute(sql)
    all = cur.fetchall()
    for i in range(len(all)):
        for j in all:
            if into == j[0]:
                treeview.insert('',i,value = (j[0],j[1],j[2],j[3]))
                break
        break

def search_all():
    conn = pymysql.connect(host='localhost', user="root", passwd="", database='stu')
    cur = conn.cursor()
    sql = 'select * from student ;'
    cur.execute(sql)
    f= cur.fetchall()
    for i in range(len(f)):
        # for j in range(len(i)):
          treeview.insert('',i,value = (f[i][0],f[i][1],f[i][2],f[i][3]))



Button(root, text="添加信息", command=add).place(relx=0.1, rely=0.2, width=100)
Button(root, text="查询个人信息", command=search).place(relx=0.3, rely=0.2, width=100)
Button(root, text="查询所有信息", command=search_all).place(relx=0.6, rely=0.2, width=100)
Button(root, text="退出程序", command=root.quit).place(relx=0.8, rely=0.2, width=100)


#有问题可以找小宝交流哦QQ:2922035952
columns = ('学号','姓名','性别','电话')
treeview = ttk.Treeview(root,show = 'headings',columns =columns)
treeview.column('学号',width = 150,anchor = 'center')
treeview.column('姓名',width = 150,anchor = 'center')
treeview.column('性别',width = 150,anchor = 'center')
treeview.column('电话',width = 150,anchor = 'center')

treeview.heading('学号',text ='学号')
treeview.heading('姓名',text ='姓名')
treeview.heading('性别',text ='性别')
treeview.heading('电话',text ='电话')


treeview.place(rely =0.3,relwidth = 0.97)


root.mainloop()

?还有最后一步——代码打包!!!

我们可以用库——pyinstaller

下载方法:打开cmd 输入 pip install pyinstaller

然后在Terminal里输入?pyinstaller -D -w xxxx.py

?然后就成功啦!!!!

最后总结一下:

这个gui界面其实还可以写成学生登录和老师登录,再来一个注册界面,都是用tk去实现,然后老师和学生登陆后的功能不同,这个是一个想法,我没有时间去写了,有的小伙伴有时间可以去思考思考哦!!也欢迎和我讨论,随时欢迎!!!

最后点点赞吧,我快你没动力分享了!!!

?

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2021-09-03 11:59:18  更:2021-09-03 11:59:42 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/18 16:47:43-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码