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

MainWindow代码

from tkinter import *
from tkinter import messagebox
from tkinter.ttk import Comboboxclass MianWindow(Frame):def __init__(self, master=None):super().__init__(master, padx=30, pady=20)self.flag = 0self.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 = 1print(self.flag)return self.flagdef 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()returnif len(self.name.get()) == 0:messagebox.askokcancel("确定/退出对话框", "插入失败,名称为空")self.clear()returnif len(self.style.get()) == 0:messagebox.askokcancel("确定/退出对话框", "插入失败,病型为空")self.clear()returnif len(self.number.get()) == 0:messagebox.askokcancel("确定/退出对话框", "插入失败,年龄为空")self.clear()returnif self.flag == 0:messagebox.askokcancel("确定/退出对话框", "插入失败,性别未选")self.clear()returnelse:from Patient.db import Connectcon = 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 Connectcon= Connect()all_ = con.Print_result()for data in all_:s = "编号:%d \t姓名:%s\t性别:%s\t病型:%s\t年龄:%s\n\n" % dataself.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 Connectcon = 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 Connectcon = Connect()all_ = con.Print_result()for data in all_:s = "编号:%d \t姓名:%s\t性别:%s\t病型:%s\t年龄:%s\n\n" % dataself.text.insert(INSERT, s)else:messagebox.askokcancel("确定/退出对话框", "执行失败,或数据不存在")self.clear()returnreturnelif len(self.id.get()) != 0 and len(self.name.get()):from Patient.db import Connectcon = Connect()re = con.update_name(int(self.id.get()), self.name.get())if re:messagebox.askokcancel("确定/退出对话框", "执行成功")self.clear()from Patient.db import Connectcon = Connect()all_ = con.Print_result()for data in all_:s = "编号:%d \t姓名:%s\t性别:%s\t病型:%s\t年龄:%s\n\n" % dataself.text.insert(INSERT, s)else:messagebox.askokcancel("确定/退出对话框", "执行失败,或数据不存在在")self.clear()returnreturnelif len(self.id.get()) != 0 and len(self.number.get()) != 0:from Patient.db import Connectcon = Connect()re = con.update_number(int(self.id.get()), self.number.get())if re:messagebox.askokcancel("确定/退出对话框", "执行成功")self.clear()from Patient.db import Connectcon = Connect()all_ = con.Print_result()for data in all_:s = "编号:%d \t姓名:%s\t性别:%s\t病型:%s\t年龄:%s\n\n" % dataself.text.insert(INSERT, s)else:messagebox.askokcancel("确定/退出对话框", "执行失败,或数据不存在在")self.clear()returnreturnelse:messagebox.askokcancel("确定/退出对话框", "执行失败,或数据不存在在")self.clear()returndef Yao_del(self):from Patient.db import Connectcon = Connect()re = con.delete_id(int(self.id.get()))if re:messagebox.askokcancel("确定/退出对话框", "执行成功")self.clear()from Patient.db import Connectcon = Connect()all_ = con.Print_result()for data in all_:s = "编号:%d \t姓名:%s\t性别:%s\t病型:%s\t年龄:%s\n\n" % dataself.text.insert(INSERT, s)else:messagebox.askokcancel("确定/退出对话框", "执行失败,或数据不存在在")self.clear()returndef Yao_select(self):self.clear()from Patient.db import Connectcon = Connect()all_ = con.Print_result()for data in all_:s = "编号:%d \t姓名:%s\t性别:%s\t病型:%s\t年龄:%s\n\n" % dataself.text.insert(INSERT, s)if __name__ == '__main__':root = Tk()root.geometry('800x500')root.title("病人信息登记")MianWindow(root)root.mainloop()

db代码

import pymysql.cursorsclass 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 redef 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 redef 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 redef 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 reif __name__ == '__main__':c = Connect()

效果图

 部署

需要的私,v:13053025350

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

深入OceanBase内部机制:系统架构与组件精讲

码到三十五 &#xff1a; 个人主页 心中有诗画&#xff0c;指尖舞代码&#xff0c;目光览世界&#xff0c;步履越千山&#xff0c;人间尽值得 ! 目录 1️⃣OceanBase 整体架构1.1 分区1.2 分片1.3 日志流1.4 对等节点1.5 多租户 2️⃣OceanBase 架构与组件详解2.1 存储层2.2 …

Disk Drill Enterprise for Mac v5.5.1515数据恢复软件中文版

Disk Drill 是 Mac 操作系统固有的Mac数据恢复软件&#xff1a;使用 Recovery Vault 轻松保护文件免遭意外删除&#xff0c;并从 Mac 磁盘恢复丢失的数据。支持大多数存储设备&#xff0c;文件类型和文件系统。 软件下载&#xff1a;Disk Drill Enterprise for Mac v5.5.1515激…

keepalived2.2.8+drbd9+nfs高可用存储部署

目录 一.本文基于上一篇文章keepalived环境来做的&#xff0c;主机信息如下 二.为两台虚拟机准备添加一块新硬盘设备 三.安装drbd9 1.使用扩展源的rpm包来下载 2.创建资源并挂载到新增的硬盘 3.主设备升级身份 4.主备两个设备手动切换身份演示 四.安装配置nfs 五.安装…

【YOLOv8】Yolov5和Yolov8网络结构的分析与对比

目录 一 YOLOv5 二 YOLOv8 yolo通常采用backbone-neck-head的网络结构。 Backbone 主要负责从输入图像中提取高层次的语义特征,常包含多个卷积层和池化层&#xff0c;构建了一个深层次的特征提取器。Neck通常用来进一步整合与调整backbone提取的特征&#xff0c;有利于将不同…

大话设计模式——24.迭代器模式(Iterator Pattern)

简介 提供一种方法顺序访问一个聚合对象中各个元素&#xff0c;而又不暴露该对象的内部实现。&#xff08;Java中使用最多的设计模式之一&#xff09; UML图 应用场景 Java的集合对象&#xff1a;Collection、List、Map、Set等都有迭代器Java ArrayList的迭代器源码 示例 简…

uniapp的h5项目 用命令起这个项目(vue-cli)

这里其实就相当于给uniapp h5套了一个vue-cli的壳&#xff08;纯属个人感觉&#xff09; 首先需要安装vue-cli 脚手架 npm install -g vue/cli然后创建项目&#xff08;这里需要在hbuilder创建&#xff09; vue create -p dcloudio/uni-preset-vue uniapp安装成功后它的结构…

OSCP靶场--Dibble

OSCP靶场–Dibble 考点(前端鉴权参数修改node.js代码注入 suid cp提权 ) 1.nmap扫描 ## ┌──(root㉿kali)-[~/Desktop] └─# nmap 192.168.173.110 -sV -sC -Pn --min-rate 2500 -p- Starting Nmap 7.92 ( https://nmap.org ) at 2024-04-09 06:36 EDT Nmap scan repor…

Jackson配置处理LocalDateTime、LocalDate等java8时间类型失效的问题解决

目录 前言 一、问题排查过程 1.1 SpringMvc是如何处理请求报文和响应报文 1.2 JacksonConfig配置排查 二、导致Jackson配置失效的原因 2.1 没有addSerializer 2.2 添加了EnableMvc注解 2.3 另外有地方配置了Jacksonhttpconver覆盖了配置 总结 前言 上一篇文章《使用Ja…

C/C++的内存管理

栈帧最主要的作用就是存储局部数据 C语言中动态内存管理方式 C语言动态内存管理 该篇详细的讲述了C语言动态内存管理的使用&#xff0c;不太懂的小伙伴可以去了解一下 C中动态内存管理方式 首先&#xff0c;C语言内存管理的方式在C中可以继续使用。但有些地方就无能为力而且使用…

Volatility-内存取证案例1-writeup--xx大赛

题目提示&#xff1a;flag{中文} 按部就班 &#xff08;1&#xff09;获取内存镜像版本信息 volatility -f 文件名 imageinfo 通过上述可知&#xff0c;镜像版本为Win7SP1X64。 &#xff08;2&#xff09;获取进程信息&#xff1a; volatility -f 镜像名 --profile第一步获取…

关于AI Agent、RAG技术揭秘:如何让人工智能更懂你?

人工智能技术正以前所未有的速度改变着我们的世界。从深度学习算法的突破到自动化和机器学习技术的进步。在这个变革的时代&#xff0c;几种前沿技术尤其引人注目&#xff0c;其中包括RAG&#xff08;Retrieval-Augmented Generation&#xff09;、AI Agent以及多模态技术。 近…

工频磁场抗扰度概述及相关注意事项

工频磁场 是指交流输变电设施产生的磁场&#xff0c;工频又称电力频率。 工频的特点是频率低、波长长&#xff1b;我国工频是50赫(Hz)&#xff0c;波长是6000千米(Km&#xff09; 工频磁场的抗扰度试验&#xff08;在有电流流过的地方都会伴生磁场&#xff0c;为了检查设备或系…

pmp就是智商税?

首先要明白的是&#xff0c;证书的价值并不在于证书本身&#xff0c;而在于学习过程中所获得的知识和经验&#xff0c;这才是证书真正的价值&#xff0c;是无法被复制的个人能力。 学习和考证都是经验的积累&#xff0c;通过这个过程可以不断地获取所需的知识&#xff0c;并加…

【Cesium学习笔记】一、加载Cesium并更换天地图底图

【Cesium学习笔记】一、加载Cesium 一、加载Cesium二、用Viewer显示地球三、更换天地图底图 Ps:本教程所有代码于同一个工程中&#xff0c;运行npm run dev默认首页为App.vue&#xff0c;只需替换App.vue的内容即可切换不同页面。 一、加载Cesium 本项目使用nvm管理node版本&…

微服务学习2

目录 一.网关路由 1.1.认识网关 1.2网关快速入门 1.2.1.创建项目 1.2.2.引入依赖 1.2.3.启动类 1.2.4.配置路由 1.3.路由过滤 二.网关登录校验 2.1网关请求处理流程 2.2网关过滤器 2.2.2网关过滤器 2.3自定义GlobalFilter 2.4.登录校验 2.4.1.JWT工具 2.4.2.登…

论文发表|《课外语文》期刊点评_投稿指南

论文发表|《课外语文》期刊点评_投稿指南 《课外语文》 知网 3版3300字符 全包 24年11-12月 可加急9-10月&#xff0c;次月出刊 &#xff08;操作周期2-3个月&#xff0c;文章不是教学类&#xff0c;不要摘要参考文献&#xff09; 《课外语文》杂志创刊于2002年&#xff…

SpringCloud集成Skywalking链路追踪和日志收集

1. 下载Agents https://archive.apache.org/dist/skywalking/java-agent/9.0.0/apache-skywalking-java-agent-9.0.0.tgz 2. 上传到服务器解压 在Spring Cloud项目中&#xff0c;每部署一个服务时&#xff0c;就拷贝一份skywalking的agent文件到该服务器上并解压。不管是部署…

基于PyAutoGUI图片定位的自动化截图工具--jmeter部分

1、计划 压测完成后需要编写性能测试报告&#xff0c;报告中所需数据截图较多&#xff0c;使用自动化操作方便快捷&#xff0c;就编写一个界面工具以便后续复用。之前编写过loadrunner报告的自动化截图脚本&#xff0c;现在用jmeter也比较多&#xff0c;就编写jmeter部分&#…

3V升9V3串LED驱动恒流WT7012

3V升9V3串LED驱动恒流WT7012 WT7012是一款性能卓越的升压转换器&#xff0c;设计用于驱动多达七串的白光LED。该器件具备宽输入工作电压范围(2-24V)&#xff0c;使其在单节或多节锂电池供电的应用中能够稳定提供背光。WT7012支持从3V起升至6V、9V、12V的恒流输出&#xff0c;通…

sqlserver问题记录

今天在利用sql查询数据时出现如下错误 在执行批处理时出现错误。错误消息为: 引发类型为“System.OutOfMemoryException”的异常。 症状 使用 SSMS 运行返回大量数据的 SQL 查询时&#xff0c;会收到类似于以下内容的错误消息&#xff1a; 执行批处理时出错。 错误消息为&…