当前位置: 首页 > article >正文

Python字典进阶:从‘学生成绩统计’到‘自动选课分析’,教你写出更地道的代码

Python字典进阶从‘学生成绩统计’到‘自动选课分析’教你写出更地道的代码在Python的世界里字典dict就像是一个神奇的魔法口袋它能以键值对的形式存储各种数据让信息的存取变得异常高效。但很多初学者往往只停留在能用的层面却忽略了字典真正的威力。本文将带你从学生成绩统计、选课分析等实际场景出发对比能用和好用的代码区别让你的Python代码更加地道、高效。1. 字典基础操作的进阶写法1.1 安全访问get() vs 直接访问新手常犯的错误是直接通过dict[key]访问不存在的键导致程序抛出KeyError。来看一个学生成绩查询的例子# 新手写法危险 student_scores {Alice: 90, Bob: 85} print(student_scores[Charlie]) # KeyError! # 高手写法安全 print(student_scores.get(Charlie, 未找到该学生)) # 输出未找到该学生get()方法的第二个参数可以指定默认值这在处理可能缺失的数据时特别有用。比如统计学生成绩时# 统计分数段人数 scores [85, 92, 78, 85, 90, 78, 92, 85] score_counts {} for score in scores: score_counts[score] score_counts.get(score, 0) 1 print(score_counts) # {85: 3, 92: 2, 78: 2, 90: 1}1.2 字典合并的艺术合并两个字典时新手可能会用循环逐个添加而高手则会用更优雅的方式# 两个班级的学生成绩 class1 {Alice: 90, Bob: 85} class2 {Charlie: 88, David: 92} # 新手写法 merged class1.copy() for k, v in class2.items(): merged[k] v # 高手写法1 merged {**class1, **class2} # 高手写法2Python 3.9 merged class1 | class22. 字典推导式简洁高效的创建方式字典推导式是Python中非常强大的特性能让代码既简洁又高效。来看一个学生信息处理的例子students [ {name: Alice, age: 20, score: 90}, {name: Bob, age: 21, score: 85}, {name: Charlie, age: 19, score: 92} ] # 创建姓名到分数的映射 # 新手写法 name_to_score {} for student in students: name_to_score[student[name]] student[score] # 高手写法 name_to_score {student[name]: student[score] for student in students}更复杂的例子筛选出成绩大于90的学生top_students {s[name]: s[score] for s in students if s[score] 90}3. collections模块中的字典工具Python的collections模块提供了几种特殊的字典类型能解决很多实际问题。3.1 defaultdict处理缺失键的优雅方案统计学生选课情况时使用defaultdict可以让代码更简洁from collections import defaultdict # 学生选课数据 student_courses [ (Alice, Math), (Bob, Physics), (Alice, Chemistry), (Charlie, Math), (Alice, Physics) ] # 统计每个学生的选课数量 course_counts defaultdict(int) for student, course in student_courses: course_counts[student] 1 print(dict(course_counts)) # {Alice: 3, Bob: 1, Charlie: 1}3.2 Counter专业的计数器统计学生成绩分布时Counter是绝佳选择from collections import Counter scores [85, 92, 78, 85, 90, 78, 92, 85] score_counter Counter(scores) print(score_counter) # Counter({85: 3, 92: 2, 78: 2, 90: 1}) print(score_counter.most_common(2)) # [(85, 3), (92, 2)]4. 复杂数据处理学生选课系统实战让我们用一个完整的选课系统例子来综合运用这些技巧。4.1 数据准备# 学生数据 students { S001: {name: Alice, grade: A}, S002: {name: Bob, grade: B}, S003: {name: Charlie, grade: A}, S004: {name: David, grade: C} } # 课程数据 courses { C101: {name: Math, capacity: 2}, C102: {name: Physics, capacity: 3}, C103: {name: Chemistry, capacity: 2} } # 选课记录 (学生ID: [课程ID列表]) enrollments { S001: [C101, C102], S002: [C101], S003: [C102, C103], S004: [] }4.2 统计每门课程的选课人数from collections import defaultdict course_counts defaultdict(int) for courses_list in enrollments.values(): for course_id in courses_list: course_counts[course_id] 1 print(dict(course_counts)) # {C101: 2, C102: 2, C103: 1}4.3 找出选课冲突的学生# 假设课程时间冲突信息 schedule { C101: Mon 9:00, C102: Mon 9:00, # 与C101时间冲突 C103: Tue 10:00 } # 找出有时间冲突的学生 conflicts defaultdict(list) for student_id, courses_list in enrollments.items(): # 收集学生所选课程的时间 times [schedule[course_id] for course_id in courses_list if course_id in schedule] # 如果有重复时间说明有冲突 if len(times) ! len(set(times)): conflicts[student_id] courses_list print(dict(conflicts)) # {S001: [C101, C102], S003: [C102, C103]}4.4 按成绩分组学生from collections import defaultdict grade_groups defaultdict(list) for student_id, info in students.items(): grade_groups[info[grade]].append(student_id) print(dict(grade_groups)) # {A: [S001, S003], B: [S002], C: [S004]}5. 性能优化避免字典使用的常见陷阱5.1 键的存在性检查检查键是否存在时新手可能会这样写if key in my_dict.keys(): # 不必要的调用keys() ...更高效的写法if key in my_dict: # 直接检查字典 ...5.2 字典视图的高效利用Python 3中的keys(), values(), items()返回的是视图对象它们比Python 2中的列表更高效# 高效遍历 for key, value in student_dict.items(): ...5.3 避免频繁的字典更新当需要批量更新字典时使用update()比逐个赋值更高效# 低效 for k, v in new_items.items(): my_dict[k] v # 高效 my_dict.update(new_items)6. 高级技巧字典的排序与自定义操作6.1 按值排序对学生成绩字典按分数排序student_scores {Alice: 90, Bob: 85, Charlie: 92} # 按分数降序排序 sorted_scores sorted(student_scores.items(), keylambda item: item[1], reverseTrue) print(sorted_scores) # [(Charlie, 92), (Alice, 90), (Bob, 85)]6.2 使用operator模块对于更复杂的排序可以使用operator模块from operator import itemgetter students [ {name: Alice, score: 90, age: 20}, {name: Bob, score: 85, age: 21}, {name: Charlie, score: 92, age: 19} ] # 按分数降序年龄升序排序 students.sort(keyitemgetter(score, age), reverseTrue)7. 实际案例自动选课分析系统让我们构建一个完整的选课分析系统展示字典在实际项目中的应用。7.1 数据加载与预处理import json from collections import defaultdict # 假设从JSON文件加载数据 def load_data(file_path): with open(file_path) as f: return json.load(f) # 加载数据 students load_data(students.json) courses load_data(courses.json) enrollments load_data(enrollments.json) # 预处理建立课程到学生的反向映射 course_to_students defaultdict(list) for student_id, course_list in enrollments.items(): for course_id in course_list: course_to_students[course_id].append(student_id)7.2 热门课程分析# 找出选课人数最多的3门课程 popular_courses sorted(course_to_students.items(), keylambda item: len(item[1]), reverseTrue)[:3] print(最受欢迎的课程) for course_id, student_ids in popular_courses: print(f{courses[course_id][name]}: {len(student_ids)}人)7.3 学生选课模式分析# 分析学生的选课数量分布 num_courses_dist defaultdict(int) for student_id in enrollments: num_courses len(enrollments[student_id]) num_courses_dist[num_courses] 1 print(学生选课数量分布) for num, count in sorted(num_courses_dist.items()): print(f选{num}门课的学生: {count}人)7.4 推荐系统雏形# 简单的课程推荐基于同年级学生的选课 def recommend_courses(student_id, n3): grade students[student_id][grade] same_grade_students [s_id for s_id, info in students.items() if info[grade] grade and s_id ! student_id] # 统计同年级学生常选的课程 course_scores defaultdict(int) for s_id in same_grade_students: for course_id in enrollments.get(s_id, []): course_scores[course_id] 1 # 排除已选课程 taken_courses set(enrollments.get(student_id, [])) recommendations [course_id for course_id in course_scores if course_id not in taken_courses] # 按受欢迎程度排序 recommendations.sort(keylambda c: course_scores[c], reverseTrue) return recommendations[:n]

相关文章:

Python字典进阶:从‘学生成绩统计’到‘自动选课分析’,教你写出更地道的代码

Python字典进阶:从‘学生成绩统计’到‘自动选课分析’,教你写出更地道的代码 在Python的世界里,字典(dict)就像是一个神奇的魔法口袋,它能以键值对的形式存储各种数据,让信息的存取变得异常高效…...

TB6612FNG双H桥电机驱动库深度解析与机器人运动控制

1. TB6612FNG_XCR库深度解析:面向嵌入式机器人控制的双路H桥驱动框架TB6612FNG_XCR并非一个简单的Arduino封装库,而是一套为真实机器人工程场景深度定制的电机控制抽象层。它在STMicroelectronics原厂TB6612FNG双H桥驱动芯片(最大持续电流1.2…...

C盘告急?保姆级教程:将Kali WSL2完美迁移至D盘并安装完整工具包(避坑指南)

Kali WSL2迁移至D盘全攻略:释放C盘空间并部署完整工具链 每次打开资源管理器看到C盘飘红的剩余空间,是不是感觉血压也跟着升高了?特别是当你在Windows上运行Kali WSL2时,那些渗透测试工具包就像一群贪吃蛇,转眼间就能吞…...

Transformer面试通关指南:从Attention到KV Cache的深度剖析

1. Transformer核心原理:从Attention机制说起 我第一次接触Transformer时,被它的Attention机制深深吸引。想象一下,你在阅读这篇文章时,眼睛会不自觉地聚焦在关键词上,这就是人类注意力的自然体现。Transformer的Self-…...

Ubuntu下配置Samba服务实现跨平台文件共享

1. 为什么需要Samba服务? 如果你同时使用Windows和Linux电脑,肯定遇到过文件互传的麻烦。用U盘拷来拷去太原始,微信传文件又受大小限制,这时候Samba就是你的救星。它就像在两个系统之间架了一座桥,让文件传输变得像在本…...

保姆级教程:用Docker一键部署YOLOv10 TensorRT模型到Jetson Orin Nano(支持USB摄像头)

极速部署YOLOv10 TensorRT模型到Jetson Orin Nano的完整实践指南 在边缘计算设备上实现高效的目标检测一直是AI开发者关注的焦点。Jetson Orin Nano作为NVIDIA推出的高性能边缘计算平台,配合YOLOv10这一最新目标检测模型,能够为各类实时视觉应用提供强大…...

3秒获取百度网盘提取码:智能工具如何提升资源获取效率300%

3秒获取百度网盘提取码:智能工具如何提升资源获取效率300% 【免费下载链接】baidupankey 项目地址: https://gitcode.com/gh_mirrors/ba/baidupankey 在信息爆炸的时代,百度网盘已成为资源分享的重要平台,但提取码的获取却常常成为效…...

2026届毕业生推荐的十大AI科研平台推荐榜单

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 在数字化内容创作这个领域当中,AI写作工具依靠自然语言处理以及深度学习技术&…...

从零打造一个丝滑的 Vue 3 返回顶部组件

从零打造一个丝滑的 Vue 3 返回顶部组件 这个组件具备以下特性&#xff1a; 智能显示&#xff1a;滚动超过指定距离&#xff08;默认 300px&#xff09;后自动出现。丝滑动画&#xff1a;使用 Vue 内置的 <Transition> 实现淡入上滑的出现 / 消失效果。平滑滚动&#xff…...

Vue3中的computed 与 watch 的区别

Vue3中的computed 与 watch 的区别 当你想要合成一个新数据用来显示时&#xff0c;选 computed。当你想要在数据变化时搞点事情&#xff08;调接口、存本地、操作 DOM&#xff09;&#xff0c;选 watch。 computed&#xff1a;计算属性 computed 主要用于数据的衍生与转换。它基…...

IPv4 与 IPv6 的核心区别

IPv4与IPv6的区别 一句话总结&#xff1a;IPv4 地址不够用、配置麻烦、安全性弱&#xff1b;IPv6 地址极多、自动配置、性能更强&#xff0c;是下一代互联网协议。 一、核心区别详情 1. 地址长度与数量IPv4&#xff1a;32位&#xff0c;地址总数约 42.9亿&#xff0c;随着互联网…...

兼容性测试覆盖多平台与多版本

兼容性测试&#xff1a;跨越平台与版本的品质保障 在数字化时代&#xff0c;软件和应用程序需要在多种操作系统、设备和版本上稳定运行。兼容性测试作为质量保障的关键环节&#xff0c;确保产品在不同环境下表现一致。随着用户终端多样化&#xff0c;覆盖多平台与多版本的测试…...

ASyncTicker:嵌入式非中断周期任务调度器

1. ASyncTicker&#xff1a;面向嵌入式实时系统的非中断式周期任务调度器在嵌入式系统开发中&#xff0c;周期性任务调度是高频刚需——LED呼吸灯、传感器采样、通信心跳包、PID控制循环、状态机轮询等场景均依赖稳定、可预测的定时触发机制。传统方案多基于硬件定时器中断服务…...

软件可解释性的决策原因与逻辑展示

## 软件可解释性&#xff1a;让算法决策不再神秘 在人工智能和机器学习快速发展的今天&#xff0c;越来越多的决策由软件系统自动完成。许多复杂的算法&#xff08;如深度神经网络&#xff09;往往被视为“黑箱”&#xff0c;其决策过程难以理解。这种不透明性可能导致用户对系…...

拆穿名词诈骗!用大白话理解晦涩难懂的AI概念谒

1. 架构背景与演进动力 1.1 从单体到碎片化&#xff1a;.NET 的开源征程 在.NET Framework 时代&#xff0c;构建系统主要围绕 Windows 操作系统紧密集成&#xff0c;采用传统的封闭式开发模式。然而&#xff0c;随着.NET Core 的推出&#xff0c;微软开启了彻底的开源与跨平台…...

再次革新 .NET 的构建和发布方式(一)帕

本文能帮你解决什么&#xff1f; 1. 搞懂FastAPI异步&#xff08;async/await&#xff09;到底在什么场景下能真正提升性能。 2. 掌握在FastAPI中正确使用多线程处理CPU密集型任务的方法。 3. 避开常见的坑&#xff08;比如阻塞操作、数据库连接池耗尽、GIL限制&#xff09;。 …...

GoCodingInMyWay淖

一、什么是 Q 饱和运算&#xff1f; 1. 核心痛点&#xff1a;普通运算的 “数值回绕” 普通算术运算&#xff08;如 ADD/SUB&#xff09;溢出时&#xff0c;数值会按补码规则 “回绕”&#xff0c;导致结果完全错误&#xff1a; 示例&#xff1a;int8_t 类型最大值 127 1 → 结…...

YOLO-Master 与 YOLO 开始朴

AI Agent 时代的沙箱需求 从 Copilot 到 Agent&#xff1a;执行能力的质变 在生成式 AI 的早期阶段&#xff0c;应用主要以“Copilot”形式存在&#xff0c;AI 仅作为辅助生成建议。然而&#xff0c;随着 AutoGPT、BabyAGI 以及 OpenAI Code Interpreter&#xff08;现为 Advan…...

微服务可观测性建设

微服务可观测性建设&#xff1a;打造高效运维的基石 在数字化转型的浪潮中&#xff0c;微服务架构凭借其灵活性和可扩展性成为企业技术演进的主流选择。随着服务数量的激增和分布式系统的复杂性提升&#xff0c;传统的监控手段已难以满足运维需求。微服务可观测性建设应运而生…...

使用 Alertmanager 配置智能告警

在微服务与云原生架构盛行的当下&#xff0c;系统监控与告警管理成为保障业务稳定性的关键环节。Alertmanager作为Prometheus生态中的核心告警组件&#xff0c;通过灵活的配置和智能路由策略&#xff0c;能够将海量告警转化为精准的行动指令&#xff0c;帮助运维团队快速响应问…...

RGBW色彩转换器:嵌入式系统高保真白光增强方案

1. RGBW色彩转换器技术解析&#xff1a;面向嵌入式显示系统的高保真白光增强方案1.1 工程背景与设计动因在LED显示与智能照明嵌入式系统中&#xff0c;RGB三色LED驱动已成主流&#xff0c;但其在高亮度白光输出场景下存在固有缺陷&#xff1a;当需呈现高亮度中性白&#xff08;…...

CopyOnWriteArrayList 实现原理

什么是CopyOnWriteArrayList&#xff1f;CopyOnWriteArrayList 是 Java 并发包 (java.util.concurrent) 中一个非常独特且重要的线程安全集合。与 Collections.synchronizedList 不同&#xff0c;CopyOnWriteArrayList 不依赖外部同步&#xff0c;而是通过内部机制实现并发控制…...

ADS1220_WE库详解:工业级24位ADC驱动与高精度传感器采集实现

1. ADS1220_WE 库深度技术解析&#xff1a;面向工业级高精度采集的 24 位四通道 ADC 驱动实现1.1 芯片级定位与工程价值ADS1220 是德州仪器&#xff08;TI&#xff09;推出的低功耗、高精度、24 位 Δ-Σ 型模数转换器&#xff0c;专为工业传感器信号调理场景设计。其核心价值不…...

VL6180X_WE中断驱动库:工业级ToF传感器低功耗实时方案

1. VL6180X_WE 库概述&#xff1a;面向工业级应用的增强型 ToF 传感器驱动 VL6180X_WE 是一款专为意法半导体&#xff08;STMicroelectronics&#xff09;VL6180X 飞行时间&#xff08;Time-of-Flight, ToF&#xff09;传感器设计的嵌入式 C 驱动库。该库并非从零构建&#xf…...

Adafruit ZeroI2S:面向Cortex-M0+/M4的零拷贝I2S音频驱动

1. 项目概述Adafruit ZeroI2S 是专为基于 SAMD21&#xff08;Arduino Zero / Adafruit Metro M0 Express / Feather M0 Express&#xff09;与 SAMD51&#xff08;Adafruit Metro M4 Express / Feather M4 Express / ItsyBitsy M4 Express&#xff09;微控制器的 Arduino 兼容开…...

Linux I/O 演进史:从管道到零拷贝,一篇串起个服务端核心原语撑

前言 在使用 kubectl get $KIND -o yaml 查看 k8s 资源时&#xff0c;输出结果中包含大量由集群自动生成的元数据&#xff08;如 managedFields、resourceVersion、uid 等&#xff09;。这些信息在实际复用 yaml 清单时需要手动清理&#xff0c;增加了额外的工作量。 使用 kube…...

-:RAG 入门-向量存储与企业级向量数据库 milvus匾

起因是我想在搞一些操作windows进程的事情时&#xff0c;老是需要右键以管理员身份运行&#xff0c;感觉很麻烦。就研究了一下怎么提权&#xff0c;顺手瞄了一眼Windows下用户态权限分配&#xff0c;然后也是感谢《深入解析Windows操作系统》这本书给我偷令牌的灵感吧&#xff…...

代码规范与团队协作效率

代码规范与团队协作效率&#xff1a;提升开发质量的关键 在软件开发中&#xff0c;代码规范与团队协作效率是决定项目成败的重要因素。统一的代码规范能减少维护成本&#xff0c;提高可读性&#xff0c;而高效的团队协作则能加速交付周期&#xff0c;降低沟通成本。尤其在多人…...

路由权限管理

路由权限管理&#xff1a;构建安全高效的前端架构 在现代前端开发中&#xff0c;路由权限管理是保障系统安全性和用户体验的核心环节。随着单页应用&#xff08;SPA&#xff09;的普及&#xff0c;前端路由的复杂性逐渐增加&#xff0c;如何动态控制用户访问权限成为开发者必须…...

使用 Python 设置 Excel 表格的行高与列宽

在技术领域&#xff0c;我们常常被那些闪耀的、可见的成果所吸引。今天&#xff0c;这个焦点无疑是大语言模型技术。它们的流畅对话、惊人的创造力&#xff0c;让我们得以一窥未来的轮廓。然而&#xff0c;作为在企业一线构建、部署和维护复杂系统的实践者&#xff0c;我们深知…...