news 2026/4/1 2:14:23

python练习项目

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
python练习项目

项目名称:简易学生成绩管理系统

功能要求:
  1. 主菜单:循环显示「1-添加成绩 2-查询成绩 3-统计分析 4-退出」;
  2. 添加成绩:输入姓名+成绩(校验0-100),追加写入student_grade.txt
  3. 查询成绩:输入姓名,读取文件返回对应成绩(无则提示);
  4. 统计分析:计算所有成绩的平均分、及格人数、优秀人数(≥90),打印结果;
  5. 退出:打印“退出系统”,终止程序;
  6. 要求:用函数封装各功能,处理输入异常(非数字、负数等)。

思路:
主菜单循环显示:while True
添加成绩:用两个列表,通过格式化字符串写文件
查询成绩:读出文件每行内容,在字符串中查找指定名字,返回整行内容
统计分析:读出文件每行内容,提取数字。提取数字可以拆分,也可以直接提取数字后组合。

我的答案:

#添加成绩到文件defscore_input(name,score):lst=[]ifscore==0:return0else:lst.append(name)lst.append(score)withopen("student_grade.txt",mode="a",encoding="utf-8")asf:f.write(f"姓名:{name},分数:{score}\n")return"已保存"#查询成绩deffind_score(name):withopen("student_grade.txt",mode="r",encoding="utf-8")asf:foriinf.readlines():ifnameini.strip():print(i)ifnotnameini.strip():print("姓名不存在")#统计成绩所有成绩的平均分、及格人数、优秀人数(≥90)defscore_info():good=0best=0withopen("student_grade.txt",mode="r",encoding="utf-8")asf:lst=f.readlines()scores=[]good=0best=0forsinlst:score=int("".join(cforcinsifc.isdigit()))ifscore>=60:good+=1ifscore>=90:best+=1scores.append(score)total=sum(scores)avg=total/len(scores)#平均分returnf"平均分:{avg:.2f},及格人数:{good}人,优秀人数:{best}人"whileTrue:func=input("「1-添加成绩 2-查询成绩 3-统计分析 4-退出」")iffunc=="4":breakeliffunc=="1":name=input("请输入姓名").strip()score=int(input("请输入成绩"))score_input(name,score)eliffunc=="2":name2=input("请输入姓名").strip()find_score(name2)eliffunc=="3":print(score_info())

错误分析:

问题类型具体表现影响
1. 输入校验缺失成绩未校验 0-100 范围、非数字输入直接报错、空姓名未过滤输入负数 / 101 / 字母会崩溃,空姓名写入文件导致统计错误
2. 统计逻辑漏洞提取成绩时若字符串无数字(如 “姓名:张三,分数:”)会报错;统计时未处理空行文件有异常行 / 空行时,int()转换失败,统计功能崩溃
3. 查询逻辑错误if not name in i.strip()仅判断最后一行,姓名不存在时提示不生效若查询的姓名不在最后一行,即使不存在也不会提示 “姓名不存在”
4. 冗余代码score_inputlst无实际作用;score_info中重复初始化good/best代码冗余,增加理解成本
5. 格式不统一写入格式为 “姓名:XX,分数:XX”,提取成绩依赖数字提取,易出错

参考答案:

# 1. 添加成绩(优化:输入校验+格式统一)defscore_input(name,score):# 输入校验:姓名非空、成绩0-100整数ifnotname.strip():return"错误:姓名不能为空!"try:score=int(score)ifnot(0<=score<=100):return"错误:成绩需在0-100之间!"exceptValueError:return"错误:成绩必须是整数!"# 统一格式:姓名 成绩(空格分隔,便于后续拆分)withopen("student_grade.txt",mode="a",encoding="utf-8")asf:f.write(f"{name.strip()}{score}\n")return"✅ 成绩添加成功!"# 2. 查询成绩(优化:遍历所有行+明确提示)deffind_score(name):ifnotname.strip():return"错误:姓名不能为空!"# 标记是否找到found=Falsewithopen("student_grade.txt",mode="r",encoding="utf-8")asf:forlineinf:line=line.strip()ifnotline:# 跳过空行continue# 按空格拆分姓名和成绩(兼容统一格式)if" "inline:stu_name,stu_score=line.split(maxsplit=1)ifstu_name==name.strip():print(f"🔍 找到成绩:{stu_name}{stu_score}分")found=Trueifnotfound:print(f"❌ 未找到姓名为「{name}」的成绩记录")# 3. 统计分析(优化:容错提取成绩+处理空文件)defscore_info():scores=[]pass_count=0# 及格人数(≥60)excellent_count=0# 优秀人数(≥90)# 处理文件不存在/空文件try:withopen("student_grade.txt",mode="r",encoding="utf-8")asf:lines=[line.strip()forlineinfifline.strip()]# 过滤空行exceptFileNotFoundError:return"❌ 暂无成绩记录(文件不存在)"ifnotlines:return"❌ 暂无成绩记录(文件为空)"# 遍历提取成绩(容错处理)forlineinlines:try:# 按空格拆分,提取成绩(兼容统一格式)_,score_str=line.split(maxsplit=1)score=int(score_str)scores.append(score)# 统计及格/优秀ifscore>=60:pass_count+=1ifscore>=90:excellent_count+=1except(ValueError,IndexError):# 跳过格式错误的行print(f"⚠️ 忽略无效行:{line}")continueifnotscores:return"❌ 无有效成绩记录"# 计算平均分avg_score=sum(scores)/len(scores)return(f"📊 成绩统计结果:\n"f"平均分:{avg_score:.2f}分\n"f"及格人数:{pass_count}人\n"f"优秀人数(≥90):{excellent_count}人")# 4. 主循环(优化:交互提示+异常处理)defmain():print("===== 学生成绩管理系统 =====")whileTrue:func=input("\n请选择操作:「1-添加成绩 2-查询成绩 3-统计分析 4-退出」\n").strip()iffunc=="4":print("👋 退出系统,感谢使用!")breakeliffunc=="1":name=input("请输入学生姓名:")score=input("请输入成绩(0-100):")result=score_input(name,score)print(result)eliffunc=="2":name2=input("请输入要查询的学生姓名:")find_score(name2)eliffunc=="3":print(score_info())else:print("❌ 输入错误,请选择1-4!")# 启动系统if__name__=="__main__":main()
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/31 16:52:31

Vue2如何通过插件实现100万文件上传的进度监控?

大文件上传方案设计与实现&#xff08;政府信创环境兼容&#xff09; 方案背景 作为北京某软件公司的开发人员&#xff0c;我负责为政府客户实现一个兼容主流浏览器和信创国产化环境的大文件上传系统。当前需求是支持4GB左右文件的上传&#xff0c;后端使用PHP&#xff0c;前…

作者头像 李华
网站建设 2026/3/25 17:15:16

强化学习系统性学习笔记(一):从理论基础到策略优化

1.1 理论溯源&#xff1a;从生物学习到数学框架强化学习的思想源头可以追溯到生物行为心理学中的"试错学习"原理。在自然界中&#xff0c;生物个体通过反复尝试不同行为并观察环境反馈&#xff0c;逐步学会选择能够带来更好结果的行动策略。这一朴素而普适的学习模式…

作者头像 李华
网站建设 2026/3/18 2:06:28

想做大数据架构师,HCIP - 大数据认证是必备吗?

不少考了HCIP大数据认证的朋友吐槽&#xff1a;持证面试大数据架构师仍屡屡碰壁&#xff0c;甚至疑惑证书是否没用。结合同行转型经验与招聘实情&#xff0c;核心问题并非证书无效&#xff0c;而是大家缺失了认证之外的关键能力——这正是转型失败的主要原因。 一、先搞懂&…

作者头像 李华
网站建设 2026/3/26 13:19:00

基于微信小程序的校友惠超市管理系统【源码文末联系】

基于微信小程序的校友惠超市管理系统 三个角色&#xff08;管理员&#xff0c;用户&#xff0c;超市&#xff09; 效果如下&#xff1a; 商品信息详情页面 登陆页面 系统首页面 管理员页面 用户管理页面 商品分类页面 商品信息页面 用户首页 研究背景 在高校数字化转型浪潮…

作者头像 李华
网站建设 2026/3/31 4:41:23

Azure AI Search 性能优化实战:从 40 秒到 8 秒的优化之旅

背景 我们的知识库问答系统使用 Azure Container Apps + Azure AI Search + Azure OpenAI 构建,架构如下: 用户请求 → Container App → AI Search (向量搜索) → OpenAI (生成回答)系统上线后,性能表现不佳: P50 响应时间:18 秒 P99 响应时间:41 秒 最慢请求:40.9 秒…

作者头像 李华
网站建设 2026/3/31 20:37:09

碱性电解槽单元槽内流体均匀性设计探秘

碱性电解槽单元槽内流体均匀性设计&#xff0c;目前行业内单元槽主要分为圆形和方形结构单元槽&#xff0c;极板包括平板型&#xff0c;乳突型&#xff0c;棱型凹凸结构&#xff0c;分析单元槽内气液比&#xff0c;速度&#xff0c;压力&#xff0c;湍动能&#xff0c;涡分布&a…

作者头像 李华