news 2026/4/27 9:34:21

【Python新手村】字典(Dict):别再大海捞针,我有专属“标签”!

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【Python新手村】字典(Dict):别再大海捞针,我有专属“标签”!

哈喽,各位 Python 练习生!

在前面的旅程里,我们见识过了列表元组集合

今天我们要聊的这位,是 Python 里的“情报局局长”——字典 (Dictionary)

想象一下,如果你在列表里存了 1000 个人的信息,想找“张三”的电话,你可能得从第 1 个人翻到第 1000 个人。这种查找方式,我们称之为**“随缘查找法”**。

但有了字典,就像你去了超市的自动储物柜:你不用记得东西在哪,你只需要拿着那张印着“取件码”的小纸条,对应的柜门就会“啪”地一声弹开。

1. 它是何方神圣?(创建字典)

字典的长相很特别,它也用花括号{}(没错,和集合抢地盘),但它里面是一对一对出现的。

这种成对的关系叫键值对 (Key-Value Pair)

# 创建一个字典 # 格式:{键: 值, 键: 值} hero_stats = { "名称": "亚瑟", "职业": "战士", "血量": 3600, "台词": "为了正义!" } print(hero_stats)

个人理解:你可以把Key(键)想象成标签,把Value(值)想象成盒子里的东西。找东西不看位置,只看标签!

2. 这里的规矩:Key 是唯一的,Value 是博爱的

字典有两个硬性规定,新手一定要记牢:

  1. Key 必须唯一:就像一个取件码只能开一个柜门。如果你存了两个一样的 Key,后来的那个会把前面的给“覆盖”掉。

  2. Key 必须不可变:Key 通常由字符串或数字担任(不能用列表)。

  3. Value 随便造:值可以是任何东西,数字、字符串、列表、甚至再嵌套一个字典。

# 覆盖演示 test_dict = {"name": "张三", "name": "李四"} print(test_dict) # 输出: {'name': '李四'} <-- 张三被无情地挤走了

3. 查数据:暴力拆解 vs 优雅索取

想看字典里的东西?有两种姿势。

姿势 A:直接抓取 (使用[])

这是最直接的方法,但也最容易“翻车”。

info = {"name": "Python", "age": 30} print(info["name"]) # 输出: Python # 如果 Key 不存在... # print(info["hobby"]) # 报错: KeyError: 'hobby' (程序直接原地炸裂)

姿势 B:优雅获取 (使用.get())

这是我强烈推荐的保命技巧

# 如果 key 不存在,它会默默返回 None,而不是报错 print(info.get("hobby")) # 输出: None # 你甚至可以设置一个“备胎”默认值 print(info.get("hobby", "这个真没有")) # 输出: 这个真没有

4. 增删改:管家的日常

字典的操作非常直观,就像操作变量一样。

增/改:直接指名道姓

如果 Key 不存在,就是新增;如果 Key 存在,就是修改。

user = {"id": 1} # 增 user["name"] = "阿强" # 改 user["id"] = 999 print(user) # {'id': 999, 'name': '阿强'}

删:踢出柜门

  • pop("key"): 删掉并把值还给你。

  • del dict["key"]: 直接消灭。

user.pop("name") print(user) # {'id': 999}

5. 遍历字典:偷看情报局的底牌

有时候你想看看字典里都有啥,有三种方式:

d = {"a": 1, "b": 2, "c": 3} # 1. 只看 Key (键) for k in d.keys(): print(k) # 2. 只看 Value (值) for v in d.values(): print(v) # 3. 都要看 (键值对) —— 最常用 for k, v in d.items(): print(f"标签是 {k}, 里面装着 {v}")

6. 个人心得:什么时候该用字典?

作为一个过来人,我有两点深刻的体会:

  1. 拒绝“魔术数字”:如果你发现你的代码里有很多student[0]student[1],过了一周你肯定忘了0是姓名还是学号。这时候请务必换成student["name"]代码的可读性会瞬间起飞

  2. 查找速度极快:字典和集合一样,底层也是哈希表。不管字典里有一万个数据还是十万个,查找某个 Key 的速度几乎都是“瞬间”。在处理大数据时,字典是当之无愧的效率之王。

关于顺序的碎碎念:在很久以前(Python 3.6 之前),字典是无序的。但现在的 Python(3.7+)默认会记住你插入数据的顺序。虽然有序了,但我们用字典的核心还是为了映射,而不是为了排序。

总结

Python 的字典 (Dict) 是一个极其聪明的管家:

  • 样子是{Key: Value}

  • 核心是映射关系,找东西快如闪电。

  • 绝招是.get(),让你的程序永不崩盘。

  • 它是处理复杂数据的终极利器。

掌握了字典,你才算真正踏入了 Python 高级应用的门槛!

喜欢这篇文章吗?点个赞,让你的 Python 技能像字典查询一样快!(。♥‿♥。)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/20 2:37:20

FaceFusion人脸融合在虚拟婚礼司仪定制中的新颖应用

FaceFusion人脸融合在虚拟婚礼司仪定制中的新颖应用 在一场现代婚礼的筹备中&#xff0c;越来越多新人开始追求个性化与科技感并重的仪式体验。当传统主持人档期紧张、风格雷同之时&#xff0c;一个大胆的想法悄然浮现&#xff1a;为何不让“自己”来主持这场人生最重要的典礼&…

作者头像 李华
网站建设 2026/4/22 12:50:17

14、FPGA 内存保护与策略实现

FPGA 内存保护与策略实现 1. 增量哈希与动态比特流完整性验证 1.1 增量哈希原理 增量哈希是一种高效的哈希计算方法。假设对一个对象(如一本书)仅修改了其中一页,增量哈希通过减去该页旧版本的哈希值,再加上修改后版本的哈希值,就能得到修改后对象的哈希值,而无需重新…

作者头像 李华
网站建设 2026/4/18 10:34:35

11、硬件安全挑战解析

硬件安全挑战解析 一、恶意硬件威胁 1.1 常见恶意硬件类型 后门与陷阱门 :后门或陷阱门可让未经授权的用户访问系统,它们可能在系统开发阶段或系统更新安装过程中被植入。 杀伤开关 :这是一种颠覆性的手段,攻击者利用它可禁用硬件或软件功能。杀伤开关能在系统开发或…

作者头像 李华
网站建设 2026/4/25 4:21:15

28、5G及未来的波束赋形与波束管理

5G及未来的波束赋形与波束管理 1. 数字波束赋形 数字波束赋形中,每个天线都连接到一个射频(RF)链,这赋予了极大的灵活性和能力,能让每个天线获得不同的功率和相位,从而实现更好的空间复用,但代价是高复杂度和高功耗。这种结构使发射机能够利用数字预编码技术同时生成多…

作者头像 李华
网站建设 2026/4/25 20:13:21

FaceFusion镜像提供使用统计报表导出功能

FaceFusion镜像新增使用统计报表导出功能&#xff1a;从“能用”到“好管”的工程进化 在AI生成内容&#xff08;AIGC&#xff09;工具日益普及的今天&#xff0c;一个有趣的现象正在发生&#xff1a;用户不再满足于“能不能换脸”&#xff0c;而是越来越关心“换了多少次”“花…

作者头像 李华