




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、Python课程设计实验报告学 院 应用技术学院 班 级 通信工程 姓 名 学 号 提交日期 2019-7-3一、实验目的:1、 熟悉python和相关软件的基本操作2、 基于本学期所学python知识,熟练应用掌握,制作符合要求的学生成绩管理系统。3、 会对程序运行中错误代码进行分析,找出合理解决方案。二、基本功能要求:1、 用户登录,如果不是管理员,只能显示显示所有学生成绩信息,如果是管理员,则显示菜单2、 录入学生的信息:姓名、学号、语文成绩、数学成绩、外语成绩3、 显示所有信息,并且要有标题4、 可以按学号或者姓名查找学生并修改或者删除学生信息5、 按平均分从高往低排序显示6、 筛选出
2、挂科学生信息三、程序运行截图:1.登陆学生信息管理系统管理员登录界面:学生登陆界面:2. 先输入数字5查询已添加的学生信息输入数字6查找挂科学生信息3. 输入数字7按照分数排序4.再次添加学生信息,查询学生信息5. 先输入数字4修改学生信息,然后输入要修改的学生学号36、输入5查询所有的学生信息。7、输入数字2删除学号为3的学生信息,再输入数字5显示全部学生信息四、总结:1.练习了数据库的打开,输入,修改和删除。2.了解了数据库的基本管理方法。3.熟悉python和相关软件的基本操作4.基于本学期所学python知识,熟练应用掌握,制作符合要求的学生成绩管理系统。5.会对程序运行中错误代码进行
3、分析,找出合理解决方案。在完成课设的过程,要先下载Python3.7和JetBrains PyCharm 和MySQL Workbench8.0,因为第一次接触这几个软件,好多知识不太懂,所以上网查资料,去图书馆查资料,多亏了王老师不厌其烦地讲解,以及同学们的帮助,在今后的Python学习中,我要再接再厉,稳扎稳打,切实提高自己的专业能力。from pymysql import *'''菜单栏'''def menu(): print('n*') print('n* 请选择你的操作 *') print('*
4、1.查询全体学生信息 *') print('* 2.新增学生信息 *') print('* 3.修改学生信息 *') print('* 4.删除学生信息 *') print('* 5.查询挂科学生 *') print('* 6.查询成绩排名 *') print('* 0.按任意键退出 *') print('n*')'''显示所有学生信息'''def searchAll(): cn = connect(host='127.
5、0.0.1', port=3306, user='root', password='123456', db='st') cur=cn.cursor() sql=str('select * from str') cur.execute(sql) data=cur.fetchall() for each in data: print(each) cur.close() # 关闭游标 cn.close() # 释放数据库资源'''添加学生信息'''def addstu(): a=i
6、nt(input('学号:') b=input('姓名:') c=int(input('语文成绩:') d = int(input('数学成绩:') e = int(input('英语成绩:') #需要判断看输入是否合法 cn = connect(host='127.0.0.1', port=3306, user='root', password='123456', db='st') cur = cn.cursor() sql= "inser
7、t into str values (%d,'%s',%d,%d,%d)"%(a,b,c,d,e) cur.execute(sql) mit() cur.close() # 关闭游标 cn.close() # 释放数据库资源 searchAll()'''修改学生信息'''def updateStu(): print('请输入您想修改学生的学号:') #需要加判断,可与addStu()配合,多一条判断,学生是否在其中 a = int(input('学号:') b = input('姓
8、名:') c = int(input('语文成绩:') d = int(input('数学成绩:') e = int(input('英语成绩:') # 需要判断看输入是否合法 cn = connect(host='127.0.0.1', port=3306, user='root', password='123456', db='st') cur = cn.cursor() sql = "update str set sn='%s',cs='
9、%d',ms='%d',es='%d' where stn='%d'" % (b, c, d, e,a) cur.execute(sql) mit() cur.close() # 关闭游标 cn.close() # 释放数据库资源 searchAll()'''删除学生信息'''def deleteStu(): dst=int(input('请输入您想删除学生的学号:') '''a=int(input("确定删除请按 1 "
10、)''' '''if(a):''' cn = connect(host='127.0.0.1', port=3306, user='root', password='123456', db='st') cur = cn.cursor() sql = "delete from str where stn=%f "%(dst) cur.execute(sql) mit() cur.close() # 关闭游标 cn.close() # 释放数据
11、库资源 '''else: print("您取消了删除!")''' searchAll()'''挂科学生名单'''def failedStu(): print('n语文挂科学生名单:') sqlChinese="select sn from str where cs <60" cn = connect(host='127.0.0.1', port=3306, user='root', password=
12、9;123456', db='st') cur = cn.cursor() cur.execute(sqlChinese) failedChinese = cur.fetchall() print(failedChinese) cur.close() # 关闭游标 cn.close() # 释放数据库资源 print('n数学挂科学生名单:') sqlMath = "select sn from str where ms <60" cn = connect(host='127.0.0.1', port=3306,
13、 user='root', password='123456', db='st') cur = cn.cursor() cur.execute(sqlMath) failedMath = cur.fetchall() print(failedMath) cur.close() # 关闭游标 cn.close() # 释放数据库资源 print('n英语挂科学生名单:') sqlEnglish = "select sn from str where es <60" cn = connect(host=
14、9;127.0.0.1', port=3306, user='root', password='123456', db='st') cur = cn.cursor() cur.execute(sqlEnglish) failedEnglish = cur.fetchall() print(failedEnglish) cur.close() # 关闭游标 cn.close() # 释放数据库资源'''按平均成绩降序排名'''def rankStu(): sqlRank="SELEC
15、T sn,cs,ms,es,(cs+ms+es)/3 AS Average FROM strORDER BY Average DESC;" cn = connect(host='127.0.0.1', port=3306, user='root', password='123456', db='st') cur = cn.cursor() cur.execute(sqlRank) mit() rank=cur.fetchall() for each in rank : print(each) cur.close() #
16、关闭游标 cn.close() # 释放数据库资源'''身份判断'''def identity(): try: administrator = "l":123456,"ll":123456, user="student1":111111,"student2":111111 loginname = input('请输入用户名:') loginpwd = input('请输入密码:') if loginname in administrat
17、or: if loginpwd="123456": print("* 尊敬的管理员您好!*") return True else: print("密码错误,请重新输入!") identity() return True elif loginname in user: if loginpwd = "111111": print("* 亲爱的同学,你好!*") searchAll() return False else: print("密码错误,请重新输入!") identity() return False else: print("*非法用户,请检查您的用户名!*") identity() finally: pass'''主函数
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年房产中介与房地产开发商合作开发协议范本
- 2025二手汽车二手买卖合同协议书1
- 2025版企业危机公关与媒体应对内训服务合同模板
- 2025版石灰石行业节能减排技术改造合同
- 2025版高科技企业实习生创新项目合作合同
- 2025年度物联网设备软件测试与功能实现合同范本
- 2025年沙发企业品牌形象设计合同下载
- 2025年度生鲜产品市场推广与销售渠道建设合同
- 贵州省思南县2025年上半年事业单位公开遴选试题含答案分析
- 医疗健康产业市场前瞻报告
- 初中全册英语常用3500词分类大全
- 电视摄像与画面编辑第1章课件
- 幕墙预埋件专项施工方案
- HDX8000系列安装配置操作指南
- 白虎汤分析课件
- 山东青年政治学院校徽校标
- 2022版义务教育英语课程标准之学业质量标准与考试评价解读PPT
- (高清正版)JJF(浙)1102-2014生物人工气候箱校准规范
- 完整解读新版《义务教育课程方案》2022年《义务教育课程方案(2022版)》PPT课件
- 《文殊真实名经》
- 幼儿各年龄段发展评估指南
评论
0/150
提交评论