news 2026/4/23 18:53:59

【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/23 11:51:32

15、FPGA内存保护策略描述、合成与示例分析

FPGA内存保护策略描述、合成与示例分析 1. 策略描述与合成 1.1 NFA与DFA构建 首先,编译器会使用Thompson算法从正则表达式构建非确定有限自动机(NFA)。之后,通过子集构造法将NFA转换为确定有限自动机(DFA),并应用Hopcroft分区算法对DFA进行最小化。 以下是这一过程的…

作者头像 李华
网站建设 2026/4/23 1:08:50

16、FPGA内存保护:系统架构、评估与策略应用

FPGA内存保护:系统架构、评估与策略应用 1. 系统架构 在FPGA系统中,参考监视器的放置位置至关重要,它需要在架构中进行合理布局,以实现不可绕过性和自我保护特性,同时将对内存系统性能的影响降至最低。不同的系统在核心数量、系统元素通信方式(直接连接、总线或网络)以…

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

19、FPGA设计安全:实现、评估与未来挑战

FPGA设计安全:实现、评估与未来挑战 1. 实现与评估 在进行系统设计时,为了达到良好的系统性能,往往需要经过一些反复尝试。比如,相互需要通信的核心应该放置得彼此靠近,其他核心也应靠近I/O引脚。可以采用多遍布局布线的方法来比较各种布局方案。 在具体的实现过程中,…

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

20、FPGA安全与计算机架构:挑战与机遇

FPGA安全与计算机架构:挑战与机遇 1. FPGA安全面临的挑战 FPGA(现场可编程门阵列)在关键系统中的广泛应用,使其安全问题变得至关重要。然而,目前FPGA面临着多种安全威胁,以下是一些主要的挑战: - 物理攻击 :对FPGA的物理攻击包括探测、功率分析、热通道、电磁辐射…

作者头像 李华