python-study-day1-(病人管理系统-带sql)

MainWindow代码

from tkinter import *
from tkinter import messagebox
from tkinter.ttk import Combobox


class MianWindow(Frame):
    def __init__(self, master=None):
        super().__init__(master, padx=30, pady=20)
        self.flag = 0
        self.pack(expand=True, fill=BOTH)
        self.id = StringVar(value=' ')
        self.name = StringVar(value=' ')
        self.style = StringVar(value='')
        self.number = StringVar(value=' ')
        self.text_box = StringVar(value=' ')

        self.Xu_setup()


    def Xu_setup(self):
        container = Frame(self)
        container.pack(side=TOP, fill=X, expand=YES, pady=10)
        Button(master=container, text='增    加', width=10, command=self.Yao_add).pack(side=LEFT, padx=20, expand=YES)
        Button(master=container, text='更    改', width=10, command=self.Yao_update).pack(side=LEFT, padx=20, expand=YES)
        Button(master=container, text='删    除', width=10, command=self.Yao_del).pack(side=LEFT, padx=20, expand=YES)
        Button(master=container, text='查    询', width=10, command=self.Yao_select).pack(side=LEFT, padx=20, expand=YES)

        container = Frame(self)
        container.pack(side=TOP, fill=X, expand=YES, pady=20)
        lbl1 = Label(master=container, text="编     号", width=10, font=("微软雅黑", 11))
        lbl1.pack(side=LEFT, padx=5)

        self.ent1 = Entry(master=container, textvariable=self.id)
        self.ent1.pack(ipady=8, side=LEFT, padx=5)

        lbl2 = Label(master=container, text="姓      名", width=10, font=("微软雅黑", 11))
        lbl2.pack(side=LEFT, padx=5)

        self.ent2 = Entry(master=container, textvariable=self.name)
        self.ent2.pack(ipady=8, side=LEFT, padx=5, fill=X)

        lbl_box = Label(master=container, text="性       别", width=10, font=("微软雅黑", 11))
        lbl_box.pack(side=LEFT, padx=5)
        self.comboxlist = Combobox(master=container, textvariable=self.text_box, width=5)
        self.comboxlist["values"] = ("男", "女")
        self.comboxlist.current(0)
        self.comboxlist.bind("<<ComboboxSelected>>", self.func)
        self.comboxlist.pack(ipady=8, side=RIGHT, fill=X)

        container = Frame(self)
        container.pack(side=TOP, fill=X, expand=YES, pady=20)
        lbl3 = Label(master=container, text="病      型", width=10, font=("微软雅黑", 11))
        lbl3.pack(side=LEFT, padx=5)

        self.ent3 = Entry(master=container, textvariable=self.style)
        self.ent3.pack(ipady=8, side=LEFT, padx=5, fill=X, expand=YES)

        lbl4 = Label(master=container, text="年      龄", width=10, font=("微软雅黑", 11))
        lbl4.pack(side=LEFT, padx=5)

        self.ent4 = Entry(master=container, textvariable=self.number)
        self.ent4.pack(ipady=8, side=LEFT, padx=5, fill=X, expand=YES)

        container = Frame(self)
        container.pack(side=TOP, fill=X, expand=YES, pady=20)

        self.text = Text(master=container)
        scroll = Scrollbar()
        scroll.pack(side=RIGHT, fill=Y)

        scroll.config(command=self.text.yview)
        self.text.config(yscrollcommand=scroll.set)

        self.text.pack(fill=X, expand=YES)

        self.text.insert(INSERT, "")

    def func(self, *args):
        self.flag = 1
        print(self.flag)
        return self.flag

    def clear(self):
        self.ent1.delete(0, "end")
        self.ent2.delete(0, "end")
        self.ent3.delete(0, "end")
        self.ent4.delete(0, "end")

    def Yao_add(self):
        if len(self.id.get()) == 0:
            messagebox.askokcancel("确定/退出对话框", "插入失败,编号为空")
            self.clear()
            return
        if len(self.name.get()) == 0:
            messagebox.askokcancel("确定/退出对话框", "插入失败,名称为空")
            self.clear()
            return
        if len(self.style.get()) == 0:
            messagebox.askokcancel("确定/退出对话框", "插入失败,病型为空")
            self.clear()
            return
        if len(self.number.get()) == 0:
            messagebox.askokcancel("确定/退出对话框", "插入失败,年龄为空")
            self.clear()
            return
        if self.flag == 0:
            messagebox.askokcancel("确定/退出对话框", "插入失败,性别未选")
            self.clear()
            return
        else:

            from Patient.db import Connect
            con = Connect()
            con.Zhou_insert(int(self.id.get()),
                            self.name.get(),
                            self.text_box.get(),
                            self.style.get(),
                            self.number.get())
            messagebox.showinfo("打印信息对话框", "插入成功")
            self.clear()
            from Patient.db import Connect
            con= Connect()
            all_ = con.Print_result()
            for data in all_:
                s = "编号:%d \t姓名:%s\t性别:%s\t病型:%s\t年龄:%s\n\n" % data
                self.text.insert(INSERT, s)

    def Yao_update(self):
        if len(self.id.get()) != 0 and len(self.name.get()) != 0 and len(self.number.get()) != 0:
            from Patient.db import Connect
            con = Connect()
            re = con.Zhou_update(int(self.id.get()), self.name.get(), self.number.get())
            if re:
                messagebox.askokcancel("确定/退出对话框", "执行成功")
                self.clear()
                from Patient.db import Connect
                con = Connect()
                all_ = con.Print_result()
                for data in all_:
                    s = "编号:%d \t姓名:%s\t性别:%s\t病型:%s\t年龄:%s\n\n" % data
                    self.text.insert(INSERT, s)
            else:
                messagebox.askokcancel("确定/退出对话框", "执行失败,或数据不存在")
                self.clear()
                return
            return
        elif len(self.id.get()) != 0 and len(self.name.get()):
            from Patient.db import Connect
            con = Connect()
            re = con.update_name(int(self.id.get()), self.name.get())
            if re:
                messagebox.askokcancel("确定/退出对话框", "执行成功")
                self.clear()
                from Patient.db import Connect
                con = Connect()
                all_ = con.Print_result()
                for data in all_:
                    s = "编号:%d \t姓名:%s\t性别:%s\t病型:%s\t年龄:%s\n\n" % data
                    self.text.insert(INSERT, s)
            else:
                messagebox.askokcancel("确定/退出对话框", "执行失败,或数据不存在在")
                self.clear()
                return
            return
        elif len(self.id.get()) != 0 and len(self.number.get()) != 0:
            from Patient.db import Connect
            con = Connect()
            re = con.update_number(int(self.id.get()), self.number.get())
            if re:
                messagebox.askokcancel("确定/退出对话框", "执行成功")
                self.clear()
                from Patient.db import Connect
                con = Connect()
                all_ = con.Print_result()
                for data in all_:
                    s = "编号:%d \t姓名:%s\t性别:%s\t病型:%s\t年龄:%s\n\n" % data
                    self.text.insert(INSERT, s)
            else:
                messagebox.askokcancel("确定/退出对话框", "执行失败,或数据不存在在")
                self.clear()
                return
            return
        else:
            messagebox.askokcancel("确定/退出对话框", "执行失败,或数据不存在在")
            self.clear()
            return

    def Yao_del(self):
        from Patient.db import Connect
        con = Connect()
        re = con.delete_id(int(self.id.get()))
        if re:
            messagebox.askokcancel("确定/退出对话框", "执行成功")
            self.clear()
            from Patient.db import Connect
            con = Connect()
            all_ = con.Print_result()
            for data in all_:
                s = "编号:%d \t姓名:%s\t性别:%s\t病型:%s\t年龄:%s\n\n" % data
                self.text.insert(INSERT, s)
        else:
            messagebox.askokcancel("确定/退出对话框", "执行失败,或数据不存在在")
            self.clear()
            return

    def Yao_select(self):
        self.clear()
        from Patient.db import Connect
        con = Connect()
        all_ = con.Print_result()
        for data in all_:
            s = "编号:%d \t姓名:%s\t性别:%s\t病型:%s\t年龄:%s\n\n" % data
            self.text.insert(INSERT, s)


if __name__ == '__main__':
    root = Tk()
    root.geometry('800x500')
    root.title("病人信息登记")
    MianWindow(root)
    root.mainloop()

db代码

import pymysql.cursors

class Connect:
    def get_connect(self):
        self.connect = pymysql.Connect(
            host='localhost',
            port=3306,
            user='root',
            password='admin123',
            database='person',
            charset='utf8')
        self.cursor = self.connect.cursor()

    def Print_result(self):
        self.get_connect()
        sql = "select * from person"
        self.cursor.execute(sql)
        all_ = self.cursor.fetchall()
        for data in all_:
            print("编号:%d \t名称:%s \t性别:%s\t类型:%s\t数值:%s\n" % data)
        self.connect.commit()
        self.connect.close()
        return all_

    def Zhou_insert(self, id, name, sex, style, number):
        self.get_connect()
        sql = "insert into person (id,name ,sex,style,number) values (%d,'%s','%s','%s','%s')"

        self.cursor.execute(sql % (id, name, sex, style, number))
        self.connect.commit()
        self.connect.close()

    def Zhou_update(self, number, name, id):
        self.get_connect()
        sql = "UPDATE person SET number ='%s',name ='%s' WHERE id = %d;"

        re = self.cursor.execute(sql % (id, name, number))

        self.connect.commit()
        self.connect.close()
        return re

    def update_name(self, name, id):  #
        self.get_connect()
        try:
            sql = "UPDATE person SET name ='%s' WHERE id = %d;"
            re = self.cursor.execute(sql % (id, name))
        except pymysql.err:
            self.connect.commit()
            print("执行错误")
        finally:
            self.connect.close()
            return re

    def update_number(self, id, number):
        self.get_connect()
        sql = "UPDATE person SET number ='%s'WHERE id = %d;"
        re = self.cursor.execute(sql % (number, id))
        self.connect.commit()
        self.connect.close()
        return re

    def delete_id(self, id):
        self.get_connect()
        sql = "DELETE FROM person WHERE id = %d"
        re = self.cursor.execute(sql % id)
        self.connect.commit()
        self.connect.close()
        return re


if __name__ == '__main__':
    c = Connect()

效果图

 部署

需要的私,v:13053025350

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/536918.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

vue3:菜单、标签页和面包屑联动效果

文章目录 1.整体思路2.实现过程 概要 提示&#xff1a;这里可以添加技术概要 例如&#xff1a; openAI 的 GPT 大模型的发展历程。 1.整体思路 在之前做的后台项目中&#xff0c;菜单、标签页和面包屑之间的联动&#xff0c;自己都是通过在路由前置守卫中&#xff0c;定义b…

铭飞SQL注入严重信息泄露【附POC】

感谢您抽出 阅读本文 MCMS是一个<完整开源的Java CMS&#xff01;基于SpringBoot 2架构&#xff0c;前端基于vue、element ui。MCMS存在SQL注入漏洞&#xff0c;攻击者可通过该漏洞获取数据库敏感信息等。目前厂商暂未发布修复措施解决此安全问题&#xff0c;建议使用此软件…

配置QtCreator能加载自定义插件的环境

配置对应环境 引言查看当前版本配置能够加载插件的环境 引言 生成的自定义插件能在QtCreator的设计器中加载&#xff0c;需要满足当前使用的QtCreator的编译时所需的Qt库和编译器。 查看当前版本 这里需要先查看自己使用的QtCreator的版本&#xff0c;即生成QtCreator时使用…

【LeetCode】回溯算法类题目详解

所有题目均来自于LeetCode&#xff0c;刷题代码使用的Python3版本 回溯算法 回溯算法是一种搜索的方法&#xff0c;在二叉树总结当中&#xff0c;经常使用到递归去解决相关的问题&#xff0c;在二叉树的所有路径问题中&#xff0c;我们就使用到了回溯算法来找到所有的路径。 …

淘宝1688京东店铺所有商品数据接口(item_search_shop接口系列,可测试)

淘宝、1688和京东都提供了API接口供开发者调用&#xff0c;以获取店铺和商品的详细数据。对于您提到的item_search_shop接口系列&#xff0c;这主要是用于获取店铺所有商品的数据。然而&#xff0c;具体的接口名称和功能可能会因平台而异&#xff0c;且可能随着平台的更新而有所…

LigaAI x 极狐GitLab,共探 AI 时代研发提效新范式

近日&#xff0c;LigaAI 和极狐GitLab 宣布合作&#xff0c;双方将一起探索 AI 时代的研发效能新范式&#xff0c;提供 AI 赋能的一站式研发效能解决方案&#xff0c;让 AI 成为中国程序员和企业发展的新质生产力。 软件研发是一个涉及人员多、流程多、系统多的复杂工程&#…

微服务面试题二

1.什么是雪崩 微服务之间相互调用&#xff0c;因为调用链中的一个服务故障&#xff0c;引起整个链路都无法访问的情况。 如何解决雪崩&#xff1f; 超时处理&#xff1a;请求超时就返回错误信息&#xff0c;不会无休止等待仓壁模式&#xff1a;限定每个业务能使用的线程数&a…

cordova后台插件开发新手教程

typora-root-url: imags cordova后台插件开发新手教程 预安装环境&#xff1a;JDK11、Android studios、nodo.js 一、环境搭建 1.安装Cordova npm install -g cordova2.创建项目 cordova create 具体命令&#xff1a; cordova create 目录名 包名 项目名 执行结果终端&am…

大模型RAG(三)检索环节(Retriever)

1. 搜索索引 &#xff08;1&#xff09;向量存储索引 最原始的实现是使用平面索引 — 查询向量和所有块向量之间的暴力计算距离。根据索引选择、数据和搜索需求&#xff0c;还可以存储元数据&#xff0c;并使用元数据过滤器来按照日期或来源等条件进行信息检索。LlamaIndex 支…

【实战JVM】打破双亲委派机制之线程上下文类加载器

个人名片&#xff1a; &#x1f43c;作者简介&#xff1a;一名大三在校生&#xff0c;喜欢AI编程&#x1f38b; &#x1f43b;‍❄️个人主页&#x1f947;&#xff1a;落798. &#x1f43c;个人WeChat&#xff1a;hmmwx53 &#x1f54a;️系列专栏&#xff1a;&#x1f5bc;️…

CS与MSF联动/shell互相反弹

Cs的shell反弹到msf 参考资料:https://blog.csdn.net/Zlirving_/article/details/113862910 先建立监听器 先建立一个监听器&#xff0c;和msf的要一一对应&#xff0c;上面的ip必须是可以ping通的大部分情况是外网ip Msf&#xff1a; use exploit/multi/handler set paylo…

Netty学习——实战篇1 BIO、NIO入门demo 备注

1 BIO 实战代码 Slf4j public class BIOServer {public static void main(String[] args) throws IOException {//1 创建线程池ExecutorService threadPool Executors.newCachedThreadPool();//2 创建ServerSocketServerSocket serverSocket new ServerSocket(8000);log.in…

高清无水印短视频素材去哪找?今天讲五个素材网站,记得收藏

在视频剪辑的世界里&#xff0c;我就像是那个经常带着一副老花镜在宝藏地图上寻宝的老海盗。每次寻宝之旅&#xff0c;我都能从九才素材网这个家门口的宝藏开始&#xff0c;然后驾驶我的老旧剪辑船&#xff0c;航向国际的深蓝大海&#xff0c;寻找那些只属于知情者的秘密宝藏。…

【C++进阶】C++异常详解

C异常 一&#xff0c;传统处理错误方式二&#xff0c;C处理的方式三&#xff0c;异常的概念四&#xff0c;异常的使用4.1 异常和捕获的匹配原则4.2 函数调用链中异常栈展开匹配原则4.3 异常的重新抛出&#xff08;异常安全问题&#xff09;4.4 RAII思想在异常中的作用 五&#…

使用Java+Maven+TestNG进行自动化测试

写作背景&#xff1a;有点Java基础的功能测试人员&#xff08;点点点工程师&#xff09;&#xff0c;所在项目有"去QE"的趋势&#xff0c;所以自己要多点亮其他技能&#xff0c;让路子走宽点。 简单说一下去QE&#xff1a;项目测试不再有专职的测试工程师来做&#x…

计算机网络——40各个层次的安全性

各个层次的安全性 安全电子邮件 Alice需要发送机密的报文m给Bob Alice 产生随机的对称秘钥&#xff0c; K s K_s Ks​使用 K s K_s Ks​对报文进行加密&#xff08;为了效率&#xff09;对 K s K_s Ks​使用Bob的公钥进行加密发送 K s ( m ) K_s(m) Ks​(m)和 K B ( K S ) K…

小程序/app/H5多端圈子社区论坛系统交友/社交/陌生人社交即时聊天私域话题社区论坛 行业圈子小程序 微信社区小程序圈子论坛社区小程序

项目介绍 这是一个社区论坛类小程序项目源码&#xff0c;可以实现用户发送自定义图文内容&#xff0c;点赞&#xff0c;评论&#xff0c;回复&#xff0c;记录评论过的帖子&#xff0c;记录发表过的帖子&#xff0c;左滑删除&#xff0c;在线实时接收消息&#xff0c;离线接收…

MySQL高级篇(索引概述、优缺点、结构 B+Tree)

目录 1、索引概述 2、索引优缺点 3、索引的结构 1、索引概述 介绍&#xff1a;索引&#xff08;index&#xff09;是帮助MySQL 高效获取数据 的 数据结构&#xff08;有序&#xff09;。在数据之外&#xff0c;数据库系统还维护着满足特定查找算法的数据结构&#xff0c;这些数…

分布式系统:缓存与数据库一致性问题

前言 缓存设计是应用系统设计中重要的一环&#xff0c;是通过空间换取时间的一种策略&#xff0c;达到高性能访问数据的目的&#xff1b;但是缓存的数据并不是时刻存在内存中&#xff0c;当数据发生变化时&#xff0c;如何与数据库中的数据保持一致&#xff0c;以满足业务系统…

java实现TCP交互

服务器端 import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import java.io.PrintWriter; import java.net.ServerSocket; import java.net.Socket; import java.util.PriorityQueue; import java.util.Scanner;public class TCP_Serv…