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

【Python 入门到精通】第 5 章:字典与结构化数据,从基础到实战全解析

前言在 Python 中列表是我们最常用的线性数据结构但它只能按顺序存储数据无法快速通过 “名称” 查找对应的值。而字典dict作为 Python 中最核心的 “键 - 值对” 数据结构完美解决了这个问题 —— 它就像一本真正的字典通过 “键key” 快速找到对应的 “值value”是我们处理结构化数据、建模真实世界的核心工具。本章我们将从字典与列表的区别入手系统掌握字典的核心方法、数据建模技巧最后通过 3 个实战项目巩固知识点帮你彻底吃透字典为后续 Python 进阶打下坚实基础。一、字典数据类型从基础到核心方法1.1 字典与列表核心区别入门必懂很多初学者会混淆字典和列表我们先通过一张表彻底区分二者明确各自的适用场景对比维度列表list字典dict存储形式有序的元素序列用[]包裹无序的键 - 值对集合用{}包裹访问方式通过索引下标访问从 0 开始通过键key访问无需下标元素特点元素可重复类型任意键不可重复类型必须不可变如字符串、数字、元组值类型任意查找效率线性查找数据量大时效率低哈希表查找时间复杂度 O (1)查找极快适用场景存储有序、需要按顺序遍历的数据存储结构化数据需要通过名称快速查找的数据一句话总结列表是 “按顺序排队”字典是 “按名字找东西”。1.2 字典的核心方法keys()、values()、items()这三个方法是字典最常用的操作也是遍历字典的核心工具我们逐一掌握1.2.1 方法定义与基础用法# 定义一个学生信息字典 student { name: 张三, age: 18, grade: 高三, score: 95 } # 1. keys()获取所有的键返回一个可迭代对象 print(student.keys()) # 输出dict_keys([name, age, grade, score]) # 2. values()获取所有的值返回一个可迭代对象 print(student.values()) # 输出dict_values([张三, 18, 高三, 95]) # 3. items()获取所有的键-值对返回可迭代的元组 print(student.items()) # 输出dict_items([(name, 张三), (age, 18), (grade, 高三), (score, 95)])1.2.2 遍历字典的三种方式实战常用# 方式1遍历所有键默认遍历字典就是遍历键 for key in student: print(f键{key}值{student[key]}) # 方式2遍历所有值 for value in student.values(): print(f值{value}) # 方式3遍历所有键-值对最常用 for key, value in student.items(): print(f{key}{value})1.3 检查字典中是否存在键或值在操作字典前我们需要先判断键 / 值是否存在避免出现KeyError错误1.3.1 检查键是否存在最常用student {name: 张三, age: 18} # 方式1用in关键字推荐简洁高效 if name in student: print(键name存在) # 输出键name存在 if score not in student: print(键score不存在) # 输出键score不存在 # 方式2用get()方法后续详细讲解 if student.get(name) is not None: print(键name存在)1.3.2 检查值是否存在# 用in关键字结合values()方法 if 张三 in student.values(): print(值张三存在) # 输出值张三存在1.4get()方法安全获取字典值get()方法是字典的 “安全访问工具”当键不存在时不会抛出KeyError而是返回默认值完美避免程序崩溃1.4.1 方法语法字典.get(键, 默认值)若键存在返回对应的值若键不存在返回指定的默认值不指定则返回None。1.4.2 实战示例student {name: 张三, age: 18} # 键存在返回对应值 print(student.get(name)) # 输出张三 # 键不存在不指定默认值返回None print(student.get(score)) # 输出None # 键不存在指定默认值返回默认值 print(student.get(score, 0)) # 输出0核心优势相比直接用student[score]访问get()方法不会因为键不存在而导致程序报错是处理不确定键的首选方法。1.5setdefault()方法安全设置默认值setdefault()方法的作用是如果键不存在就插入键 - 值对如果键存在就返回对应的值不修改原字典常用于初始化字典、避免重复赋值。1.5.1 方法语法字典.setdefault(键, 默认值)1.5.2 实战示例student {name: 张三, age: 18} # 键不存在插入键-值对返回新值 result student.setdefault(score, 90) print(result) # 输出90 print(student) # 输出{name: 张三, age: 18, score: 90} # 键存在返回对应的值不修改原字典 result student.setdefault(score, 95) print(result) # 输出90原字典中score的值是90不修改 print(student) # 输出{name: 张三, age: 18, score: 90}典型应用场景统计字符串中每个字符的出现次数s hello world count {} for char in s: # 若字符不存在初始化为0存在则返回当前计数 count.setdefault(char, 0) count[char] 1 print(count) # 输出{h:1, e:1, l:3, o:2, :1, w:1, r:1, d:1}二、美观地输出字典让数据更易读当字典嵌套层级深、数据量大时直接print()输出的格式杂乱难以阅读。我们可以用pprint模块实现美观输出2.1 基础用法import pprint # 定义一个嵌套字典 student { name: 张三, age: 18, scores: {语文: 90, 数学: 95, 英语: 88}, hobbies: [篮球, 读书, 编程] } # 普通print输出格式杂乱 print(student) # 输出{name: 张三, age: 18, scores: {语文: 90, 数学: 95, 英语: 88}, hobbies: [篮球, 读书, 编程]} # pprint美观输出自动换行、缩进层级清晰 pprint.pprint(student) # 输出 # {age: 18, # hobbies: [篮球, 读书, 编程], # name: 张三, # scores: {语文: 90, 数学: 95, 英语: 88}}2.2 进阶参数自定义格式# indent设置缩进量width设置每行最大宽度sort_dicts是否按键排序 pprint.pprint(student, indent4, width30, sort_dictsFalse)三、用数据结构对真实世界建模从井字棋到嵌套数据字典的核心价值就是用结构化的数据建模真实世界的复杂对象。我们从简单的井字棋入手逐步掌握嵌套字典和列表的使用。3.1 井字棋盘建模列表 字典的基础应用井字棋是 3×3 的棋盘我们可以用列表嵌套列表建模棋盘用字典存储游戏状态# 1. 建模3×3棋盘用列表嵌套列表初始为空 board [ [, , ], [, , ], [, , ] ] # 2. 建模游戏状态用字典存储玩家、当前回合、棋盘 game { player1: X, player2: O, current_player: X, board: board, winner: None } # 3. 打印棋盘遍历列表美观输出 def print_board(board): for row in board: print( | .join(row)) print(- * 5) print_board(game[board])3.2 嵌套的字典和列表建模复杂对象真实世界的对象往往是多层嵌套的比如一个班级的学生信息我们可以用列表存储多个学生每个学生用字典存储信息实现复杂数据的结构化管理# 建模班级学生信息列表嵌套字典 class_info { class_name: 高三(1)班, teacher: 李老师, students: [ {name: 张三, age: 18, scores: {语文: 90, 数学: 95}}, {name: 李四, age: 18, scores: {语文: 85, 数学: 92}}, {name: 王五, age: 18, scores: {语文: 92, 数学: 88}} ] } # 遍历所有学生计算平均分 for student in class_info[students]: scores student[scores].values() avg_score sum(scores) / len(scores) print(f{student[name]}的平均分{avg_score:.1f})核心技巧列表用于存储同类型、有序的集合如学生列表、棋盘行字典用于存储有名称、结构化的对象如学生信息、游戏状态嵌套用列表 字典的组合建模任意复杂度的真实世界对象。四、实战项目从入门到进阶巩固知识点项目 1国际象棋字典验证器需求国际象棋棋盘是 8×8 的每个格子用(列, 行)表示列从 a 到 h行从 1 到 8。我们需要实现一个验证器判断输入的坐标是否合法并用字典存储棋盘上的棋子。代码实现# 1. 初始化国际象棋棋盘字典存储棋子键为坐标值为棋子名称 chess_board {} # 2. 定义合法坐标范围 valid_cols [a, b, c, d, e, f, g, h] valid_rows [1, 2, 3, 4, 5, 6, 7, 8] # 3. 坐标验证函数 def is_valid_pos(pos): if len(pos) ! 2: return False col, row pos[0].lower(), pos[1] return col in valid_cols and row in valid_rows # 4. 添加棋子函数 def add_piece(pos, piece): if not is_valid_pos(pos): print(f坐标{pos}不合法) return False chess_board[pos] piece print(f在{pos}添加棋子{piece}成功) return True # 5. 测试 add_piece(a1, 白车) # 合法添加成功 add_piece(h8, 黑车) # 合法添加成功 add_piece(i9, 白兵) # 不合法提示错误 # 6. 打印所有棋子 print(\n当前棋盘棋子) for pos, piece in chess_board.items(): print(f{pos}{piece})项目 2好玩游戏的物品清单需求实现一个游戏物品清单支持添加物品、删除物品、查看清单、统计总数量用字典存储物品键为物品名称值为数量。代码实现# 初始化物品清单 inventory {} # 1. 添加物品 def add_item(item, count1): # 用setdefault()安全设置默认值 inventory.setdefault(item, 0) inventory[item] count print(f添加{count}个{item}当前{item}数量{inventory[item]}) # 2. 删除物品 def remove_item(item, count1): if item not in inventory: print(f物品{item}不存在) return False if inventory[item] count: print(f{item}数量不足当前仅{inventory[item]}个) return False inventory[item] - count if inventory[item] 0: del inventory[item] print(f删除{count}个{item}当前{item}数量{inventory.get(item, 0)}) return True # 3. 查看清单 def display_inventory(): print(\n当前物品清单) total 0 for item, count in inventory.items(): print(f{item}{count}个) total count print(f总物品数量{total}) # 4. 测试 add_item(剑, 1) add_item(药水, 5) add_item(药水, 3) # 药水数量变为8 remove_item(药水, 2) # 药水数量变为6 display_inventory()项目 3列表到字典的函数针对好玩游戏的物品清单需求游戏中物品可能以列表形式存储如[剑, 药水, 药水, 盾]我们需要实现一个函数将列表转换为物品清单字典统计每个物品的数量。代码实现# 列表转字典函数 def list_to_dict(item_list): inventory {} for item in item_list: # 用setdefault()初始化计数 inventory.setdefault(item, 0) inventory[item] 1 return inventory # 测试 item_list [剑, 药水, 药水, 盾, 剑, 药水, 盾, 盾] inventory list_to_dict(item_list) # 打印转换后的清单 print(列表转字典后的物品清单) for item, count in inventory.items(): print(f{item}{count}个)五、本章小结核心知识点总结字典核心键 - 值对结构键不可重复、不可变通过键快速查找值查找效率 O (1)核心方法keys()/values()/items()用于遍历get()用于安全访问setdefault()用于安全初始化数据建模列表存储有序集合字典存储结构化对象嵌套组合建模复杂真实世界实战技巧用字典统计计数、用嵌套结构管理复杂数据、用pprint美观输出。六、习题与拓展巩固提升基础习题定义一个字典存储你的个人信息姓名、年龄、爱好、成绩用items()遍历输出实现一个函数统计字符串中每个单词的出现次数用字典用嵌套字典建模一个通讯录存储多个联系人的姓名、电话、邮箱。拓展提升完善井字棋游戏代码实现胜负判断、玩家交替落子为游戏物品清单添加 “物品分类” 功能用嵌套字典按分类管理物品如武器、消耗品、防具。结语字典是 Python 中最灵活、最实用的数据结构之一掌握字典就掌握了 Python 处理结构化数据的核心能力。本章从基础操作到实战项目系统梳理了字典的核心知识点希望能帮你彻底吃透字典为后续 Python 进阶如面向对象、数据分析打下坚实基础。如果觉得本文有用欢迎点赞、收藏、关注后续将持续更新 Python 入门到精通系列文章带你从零基础到 Python 大神

相关文章:

【Python 入门到精通】第 5 章:字典与结构化数据,从基础到实战全解析

前言在 Python 中,列表是我们最常用的线性数据结构,但它只能按顺序存储数据,无法快速通过 “名称” 查找对应的值。而字典(dict) 作为 Python 中最核心的 “键 - 值对” 数据结构,完美解决了这个问题 —— …...

从FP32到INT8:在RK3588开发板上实测RKNN量化对YOLOv5推理速度与精度的真实影响

从FP32到INT8:在RK3588开发板上实测RKNN量化对YOLOv5推理速度与精度的真实影响 当你在RK3588开发板上部署YOLOv5模型时,是否遇到过这样的困境:模型精度令人满意,但推理速度却无法满足实时性要求?这就是我们今天要探讨的…...

基于RexUniNLU的Java企业级文本分析系统构建指南

基于RexUniNLU的Java企业级文本分析系统构建指南 1. 引言 想象一下这样的场景:你的电商平台每天收到数万条客户反馈,客服团队需要手动分类处理;法务部门每天要审核大量合同,寻找关键条款;市场团队需要从海量评论中提…...

OpenClaw云端体验版:Phi-3-vision-128k-instruct沙盒环境快速验证

OpenClaw云端体验版:Phi-3-vision-128k-instruct沙盒环境快速验证 1. 为什么选择云端沙盒体验 当我第一次听说OpenClaw时,就被它"让AI像人类一样操作电脑"的理念吸引了。但作为一个谨慎的技术人,我习惯在正式投入时间前先做可行性…...

WPF Chart控件从入门到精通:手把手教你打造动态数据看板

WPF Chart控件从入门到精通:手把手教你打造动态数据看板 在数据驱动的时代,能够直观呈现业务指标的动态数据看板已成为企业决策的标配工具。作为.NET开发者,掌握WPF Chart控件的深度应用,意味着你能够快速构建专业级的数据可视化解…...

LiuJuan Z-Image Generator在内容创作中的落地:自媒体头像/封面图定制化生产方案

LiuJuan Z-Image Generator在内容创作中的落地:自媒体头像/封面图定制化生产方案 你是不是也遇到过这样的烦恼?想给自己的自媒体账号换个有辨识度的头像,或者为下一期视频设计一个吸引眼球的封面图,结果要么是找不到合适的素材&a…...

从URDF到MoveIt!手把手教你为六轴机械臂配置运动规划(避坑指南)

从URDF到MoveIt!六轴机械臂运动规划实战全解析 当你第一次在RViz中看到自己设计的六轴机械臂模型时,那种成就感难以言表。但很快你会发现,静态展示只是万里长征的第一步——如何让这个钢铁手臂真正"活"起来?这就是MoveI…...

手把手教你用FPGA(EP4CE6)驱动M25P16 Flash:从SPI时序图到Verilog状态机的保姆级实战

FPGA实战:EP4CE6驱动M25P16 Flash的SPI状态机设计全解析 当我在实验室第一次成功通过FPGA读取到Flash芯片中的数据时,那种成就感至今难忘。对于初学者来说,理解如何将芯片手册中的时序图转化为可运行的Verilog代码,就像学习一门新…...

避坑指南:ROS2与NVIDIA Isaac Sim联调机械臂,我踩过的那些“坑”

ROS2与NVIDIA Isaac Sim联调机械臂:开发者避坑实战手册 当机械臂在虚拟环境中突然抽搐起舞,当关节角度指令像被黑洞吞噬般消失无踪——这些场景对尝试将ROS2与NVIDIA Isaac Sim联调的开发者来说并不陌生。作为经历过数十次配置崩溃的老兵,我将…...

新手友好:黑丝空姐-造相Z-Turbo镜像的详细操作步骤

新手友好:黑丝空姐-造相Z-Turbo镜像的详细操作步骤 你是不是对AI生成图片很感兴趣,特别是想试试那些能生成特定风格图片的模型?今天要介绍的这个“黑丝空姐-造相Z-Turbo”镜像,就是一个专门用于生成黑丝空姐风格图片的AI模型服务…...

MicroBlaze 大程序 Flash 固化与自启

MicroBlaze 大程序 Flash 固化与自启1. 核心原因分析:为什么大程序不能直接固化?在带 ARM 核的 FPGA(如 Zynq 系列)中,硬件内置了 BootROM 和 FSBL 机制,可以自动处理镜像打包和 DDR 初始化。但在 纯 FPGA&…...

GLM-4-9B-Chat-1M效果惊艳:长篇小说逻辑梳理+代码库跨文件调试实录

GLM-4-9B-Chat-1M效果惊艳:长篇小说逻辑梳理代码库跨文件调试实录 1. 开篇:本地大模型的突破性体验 当我第一次用GLM-4-9B-Chat-1M处理完一整部长篇小说后,真的被震撼到了。这不是那种需要联网等待的云端服务,而是在我自己电脑上…...

Qwen3-VL-8B优化指南:如何选择量化模型,提升Mac运行速度

Qwen3-VL-8B优化指南:如何选择量化模型,提升Mac运行速度 1. 引言:Mac上的多模态AI挑战 在Mac设备上运行大型视觉-语言模型一直是个技术难题。传统多模态模型通常需要高端GPU和大量显存,而MacBook的硬件配置往往难以满足这些要求…...

Qwen3-ASR-1.7B开发入门:MySQL数据库集成教程

Qwen3-ASR-1.7B开发入门:MySQL数据库集成教程 1. 引言 语音识别技术正在改变我们与设备交互的方式,而将识别结果持久化存储是许多实际应用的关键需求。今天我们来聊聊如何将Qwen3-ASR-1.7B这个强大的语音识别模型与MySQL数据库结合起来,让你…...

告别预编译库:手把手教你从源码构建OpenCL开发环境(ARM64平台专属指南)

告别预编译库:手把手教你从源码构建OpenCL开发环境(ARM64平台专属指南) 在ARM64架构的嵌入式开发领域,预编译的OpenCL库往往成为性能调优的瓶颈。当你在RK3588这样的高性能平台上开发时,是否遇到过驱动版本不匹配、API…...

阿里通义Z-Image-GGUF使用心得:小白也能玩转的高质量文生图

阿里通义Z-Image-GGUF使用心得:小白也能玩转的高质量文生图 1. 30秒快速上手:从零到第一张AI画作 你是不是也曾在社交媒体上看到那些惊艳的AI生成图片,心里想着"这一定很难操作"?今天我要告诉你一个好消息&#xff1a…...

OpenClaw故障自愈:Qwen3.5-9B诊断脚本错误与自动重试机制

OpenClaw故障自愈:Qwen3.5-9B诊断脚本错误与自动重试机制 1. 为什么需要故障自愈能力 上周我在用OpenClaw自动化处理一批Python数据分析脚本时,遇到了一个典型问题:凌晨3点脚本运行失败,直到早上8点查看日志才发现问题。这种&qu…...

从“手扫感应灯”拆解开始:聊聊三极管放大电路在生活中的那些实用设计

从“手扫感应灯”拆解开始:聊聊三极管放大电路在生活中的那些实用设计 每次深夜回家,摸黑找开关的体验总让人抓狂。直到我在玄关装了一盏挥手即亮的感应灯,这个不到50元的小玩意儿彻底改变了我的生活习惯——无需触碰,手在灯前轻轻…...

Dify平台低代码集成:可视化工作流编排Pixel Couplet Gen创作过程

Dify平台低代码集成:可视化工作流编排Pixel Couplet Gen创作过程 1. 春联创作的传统痛点与AI解决方案 每到春节前夕,无论是企业还是个人,都会面临一个共同的需求:创作富有节日氛围的春联。传统方式下,这个过程往往需…...

OLLAMA部署本地大模型新选择:LFM2.5-1.2B-Thinking支持思维链可视化输出

OLLAMA部署本地大模型新选择:LFM2.5-1.2B-Thinking支持思维链可视化输出 1. 模型简介:口袋里的AI大脑 LFM2.5-1.2B-Thinking是一个专门为设备端部署设计的智能文本生成模型,它在保持小巧体积的同时,提供了令人惊喜的智能水平。这…...

OpenClaw日程管理:千问3.5-9B解析邮件创建待办

OpenClaw日程管理:千问3.5-9B解析邮件创建待办 1. 为什么需要AI助手管理日程? 每天早上打开邮箱,总能看到十几封未读邮件——会议邀请、项目更新、待办提醒混杂在一起。上周我就因为漏看了一封包含截止日期变更的邮件,差点耽误了…...

深入解析航顺HK32F030C8T6与STM32F030的兼容性差异及实战调优

1. 航顺HK32F030C8T6与STM32F030的硬件差异解析 第一次拿到航顺HK32F030C8T6这颗国产MCU时,我下意识以为它和STM32F030可以完全互换。但实际在智能家居项目中踩坑后才发现,两者的硬件差异远比想象中多。最明显的区别就是主频——STM32F030最高只能跑到48…...

Qwen3-ASR-1.7B安防应用:语音监控智能分析系统

Qwen3-ASR-1.7B安防应用:语音监控智能分析系统 1. 引言 想象一下这样的场景:一个大型商场里,监控摄像头捕捉到了异常情况,但保安人员需要同时盯着几十个屏幕,很难第一时间发现所有问题。或者在一个工厂车间里&#x…...

Swin2SR在Linux系统下的部署与优化指南

Swin2SR在Linux系统下的部署与优化指南 本文详细讲解如何在Linux系统中部署和优化Swin2SR超分辨率模型,从环境配置到性能调优,提供完整的实践指南。 1. 引言 如果你正在寻找一种方法让低分辨率图像变得清晰锐利,Swin2SR可能是你需要的解决方…...

实战Electron跨进程通信实现SerialPort串口数据交互

1. 为什么Electron 9.0需要跨进程通信处理串口? 第一次用Electron对接工业秤重设备时,我直接把SerialPort代码写在渲染进程,结果控制台突然报错——就像被泼了盆冷水。原来从Electron 9.0开始,安全策略禁止渲染进程直接调用原生No…...

避坑指南:在Nacos 2.2.3源码编译适配达梦DM8时,我遇到的5个典型错误及解决方法

Nacos 2.2.3源码编译适配达梦DM8实战:5个典型错误与深度解决方案 最近在将Nacos 2.2.3适配达梦DM8数据库的过程中,我踩了不少坑。这些坑有些是达梦特有的语法问题,有些是Nacos源码中的隐藏陷阱,还有些是环境配置的玄学问题。今天就…...

YOLO12在Java企业级应用中的集成方案

YOLO12在Java企业级应用中的集成方案 1. 引言 想象一下,你正在开发一个智能监控系统,需要实时分析成千上万的视频流,准确识别其中的车辆、行人和其他关键目标。传统的解决方案要么准确率不够,要么处理速度跟不上业务需求。这时候…...

从PHY芯片看工业网络精准时钟:IEEE 1588v2(PTP)协议实现与选型指南

1. 工业网络为何需要纳秒级时钟同步? 在工业自动化生产线或通信基站里,你可能见过这样的场景:几十台机械臂协同装配零件时,某个关节动作偏差1毫秒,整个产品就可能报废;5G基站切换时,时间误差超过…...

揭秘.NET 9全新AI Runtime:如何绕过JIT瓶颈,让ONNX模型推理延迟直降41%?

第一章:.NET 9全新AI Runtime的架构演进与设计哲学.NET 9 引入了原生 AI Runtime,标志着运行时从通用计算平台向智能工作负载优先平台的关键跃迁。其核心并非简单叠加模型推理能力,而是重构执行模型——将提示工程、token 编排、异步流式推理…...

Spring Cloud进阶--分布式权限校验OAuth浅

一、核心问题及解决方案(按踩坑频率排序) 问题 1:误删他人持有锁——最基础也最易犯的漏洞 成因:释放锁时未做身份校验,直接执行 DEL 命令删除键。典型场景:服务 A 持有锁后,业务逻辑耗时超过锁…...