news 2026/6/9 17:19:15

Python字典操作与应用详解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Python字典操作与应用详解

Python 字典详解

1. 字典基础

什么是字典?

字典是Python中一种可变、无序的键值对集合。每个键值对用冒号分隔,键值对之间用逗号分隔,整个字典包括在花括号{}中。

# 创建字典person={"name":"Alice","age":25,"city":"New York"}# 访问值print(person["name"])# 输出: Aliceprint(person.get("age"))# 输出: 25

字典的特点

  • 键必须是不可变类型(字符串、数字、元组)
  • 键必须是唯一的
  • 值可以是任意类型
  • 无序(Python 3.7+ 保持了插入顺序)

2. 创建字典的方法

# 方法1: 直接创建dict1={"name":"Alice","age":25}# 方法2: 使用 dict() 构造函数dict2=dict(name="Bob",age=30)# 方法3: 从键值对列表创建dict3=dict([("name","Charlie"),("age",35)])# 方法4: 使用字典推导式dict4={x:x**2forxinrange(5)}# {0: 0, 1: 1, 2: 4, 3: 9, 4: 16}# 方法5: 使用 fromkeys() 创建默认值字典keys=["name","age","city"]dict5=dict.fromkeys(keys,None)# {'name': None, 'age': None, 'city': None}

3. 常用字典操作

访问元素

person={"name":"Alice","age":25}# 使用键访问print(person["name"])# Alice# 使用 get() 方法(避免 KeyError)print(person.get("age"))# 25print(person.get("height","Not found"))# 默认值: Not found# 检查键是否存在print("name"inperson)# Trueprint("height"inperson)# False

添加和修改元素

person={"name":"Alice"}# 添加新键值对person["age"]=25person["city"]="New York"# 修改值person["age"]=26# 使用 update() 方法person.update({"job":"Engineer","age":27})

删除元素

person={"name":"Alice","age":25,"city":"NY"}# 删除指定键delperson["city"]# 使用 pop() 删除并返回值age=person.pop("age")# 返回 25# 使用 popitem() 删除最后一个键值对(Python 3.7+)item=person.popitem()# 返回 ('name', 'Alice')# 清空字典person.clear()# 删除整个字典delperson

4. 字典遍历

student={"name":"Alice","age":22,"major":"Computer Science","grades":{"math":90,"english":85}}# 遍历键forkeyinstudent:print(key)# 遍历键(显式)forkeyinstudent.keys():print(key)# 遍历值forvalueinstudent.values():print(value)# 遍历键值对forkey,valueinstudent.items():print(f"{key}:{value}")# 遍历嵌套字典forsubject,gradeinstudent["grades"].items():print(f"{subject}:{grade}")

5. 字典方法

person={"name":"Alice","age":25,"city":"NY"}# keys() - 返回所有键print(list(person.keys()))# ['name', 'age', 'city']# values() - 返回所有值print(list(person.values()))# ['Alice', 25, 'NY']# items() - 返回所有键值对print(list(person.items()))# [('name', 'Alice'), ('age', 25), ('city', 'NY')]# get() - 安全获取值print(person.get("height",170))# 170# setdefault() - 获取值,如果不存在则设置默认值person.setdefault("country","USA")# copy() - 创建浅拷贝person_copy=person.copy()# fromkeys() - 从序列创建字典new_dict=dict.fromkeys(["a","b","c"],0)# {'a': 0, 'b': 0, 'c': 0}

6. 字典推导式

# 基本推导式squares={x:x**2forxinrange(1,6)}# {1: 1, 2: 4, 3: 9, 4: 16, 5: 25}# 带条件的推导式even_squares={x:x**2forxinrange(10)ifx%2==0}# 转换现有字典original={"a":1,"b":2,"c":3}doubled={k:v*2fork,vinoriginal.items()}# 交换键值swapped={v:kfork,vinoriginal.items()}

7. 嵌套字典

# 嵌套字典示例students={"001":{"name":"Alice","age":22,"grades":{"math":90,"english":85}},"002":{"name":"Bob","age":23,"grades":{"math":78,"english":92}}}# 访问嵌套值print(students["001"]["name"])# Aliceprint(students["002"]["grades"]["math"])# 78# 修改嵌套值students["001"]["age"]=23students["001"]["grades"]["history"]=88

8. 字典排序

# Python 3.7+ 字典保持插入顺序,但有时需要排序scores={"Charlie":85,"Alice":95,"Bob":90}# 按键排序sorted_by_key=dict(sorted(scores.items()))# {'Alice': 95, 'Bob': 90, 'Charlie': 85}# 按值排序sorted_by_value=dict(sorted(scores.items(),key=lambdaitem:item[1]))# {'Charlie': 85, 'Bob': 90, 'Alice': 95}# 按值降序排序sorted_by_value_desc=dict(sorted(scores.items(),key=lambdaitem:item[1],reverse=True))

9. 字典合并

# Python 3.5+ 使用 ** 运算符dict1={"a":1,"b":2}dict2={"b":3,"c":4}merged={**dict1,**dict2}# {'a': 1, 'b': 3, 'c': 4}# Python 3.9+ 使用 | 运算符merged=dict1|dict2# {'a': 1, 'b': 3, 'c': 4}# 使用 update() 方法dict1.update(dict2)# dict1 被修改# 使用字典推导式merged={k:vfordin[dict1,dict2]fork,vind.items()}

10. 实用示例

# 示例1: 单词频率统计defword_frequency(text):words=text.lower().split()frequency={}forwordinwords:frequency[word]=frequency.get(word,0)+1returnfrequency text="apple banana apple orange banana apple"print(word_frequency(text))# {'apple': 3, 'banana': 2, 'orange': 1}# 示例2: 配置管理config={"database":{"host":"localhost","port":5432,"name":"mydb"},"server":{"host":"0.0.0.0","port":8000}}# 示例3: 缓存实现classSimpleCache:def__init__(self,max_size=100):self.cache={}self.max_size=max_sizedefget(self,key):returnself.cache.get(key)defset(self,key,value):iflen(self.cache)>=self.max_size:self.cache.pop(next(iter(self.cache)))self.cache[key]=value

11. 注意事项

# 1. 键必须是不可变类型# 正确的键valid_keys={"string":"value",123:"value",(1,2,3):"value"}# 错误的键(列表不能作为键)# invalid = {[1, 2]: "value"} # TypeError# 2. 避免在遍历时修改字典data={"a":1,"b":2,"c":3}# for key in data:# if key == "b":# del data[key] # RuntimeError# 正确的做法keys_to_remove=[]forkeyindata:ifkey=="b":keys_to_remove.append(key)forkeyinkeys_to_remove:deldata[key]# 3. 使用 defaultdict 处理缺失键fromcollectionsimportdefaultdict word_count=defaultdict(int)# 默认值为0word_count["apple"]+=1# 不需要检查键是否存在

总结

Python字典是一种非常高效和灵活的数据结构,特别适合存储和查询键值对数据。掌握字典的各种操作和方法,能够大大提高编程效率。字典在Python中的应用非常广泛,从简单的数据存储到复杂的算法实现都离不开它。

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

LFM2.5-1.2B-Thinking效果惊艳:Ollama本地部署多语言混合生成实测

LFM2.5-1.2B-Thinking效果惊艳:Ollama本地部署多语言混合生成实测 你有没有试过在自己笔记本上跑一个真正“能思考”的小模型?不是那种一问一答的机械复读机,而是能理解上下文、切换中英日韩、边想边写、还能把复杂问题拆解清楚的轻量级选手…

作者头像 李华
网站建设 2026/6/6 11:41:55

用SenseVoiceSmall做了个智能客服系统,效果超预期

用SenseVoiceSmall做了个智能客服系统,效果超预期 最近在搭建一个轻量级智能客服系统时,我试了几个语音识别方案,最后选定了阿里开源的 SenseVoiceSmall 模型。不是因为它名气最大,而是它真正解决了我在实际业务中卡住的几个关键…

作者头像 李华
网站建设 2026/6/6 13:07:37

Youtu-2B自动代码补全:IDE插件集成部署教程

Youtu-2B自动代码补全:IDE插件集成部署教程 1. 为什么你需要一个轻量又靠谱的代码助手? 你有没有过这样的经历:在写Python脚本时卡在某个函数参数上,翻文档耗时两分钟;调试JavaScript时反复检查括号匹配,…

作者头像 李华
网站建设 2026/6/8 16:21:55

Qwen3-4B Instruct-2507实战案例:建筑行业施工方案生成+安全规范嵌入

Qwen3-4B Instruct-2507实战案例:建筑行业施工方案生成安全规范嵌入 1. 为什么选Qwen3-4B Instruct-2507做施工方案这件事? 你有没有遇到过这样的场景: 工地刚进场,项目经理催着要三天内交出《深基坑支护专项施工方案》&#xf…

作者头像 李华
网站建设 2026/6/7 13:44:05

ANIMATEDIFF PRO效果展示:老电影颗粒感+胶片划痕的复古滤镜生成

ANIMATEDIFF PRO效果展示:老电影颗粒感胶片划痕的复古滤镜生成 1. 这不是“加个滤镜”那么简单——你看到的每一帧,都在模拟1930年代的胶片心跳 你有没有试过把一段现代视频丢进老式放映机?不是简单调个色温、加点噪点就完事的那种。而是让…

作者头像 李华