在Python的世界里,字典是一种无处不在的数据结构,以其独特的方式处理信息和数据。想象一下,如果你拥有一个万能的箱子,能够按照名字立刻找到里面的任何一个物品,那么Python字典就是编程世界中的这个万能箱子。无论是快速访问数据、数据存储还是进行复杂的数据操作,字典都能以其高效和灵活的特性,成为Python编程不可或缺的一部分。
合集:《Python基础》
分类:数据类型
(关注并收藏,API快查,一文全覆盖,随时补充更新)
接下来,我将给大家介绍:
- Python字典的特点
- 完整的方法列表
- 常见的操作示例
- 字典的创建和初始化
- 访问元素
- 添加和修改元素
- 删除元素
- 遍历字典
- 字典推导式
- 嵌套字典
- 字典的方法
- 字典的性能
0.Python字典的特点
- 键值对存储结构:Python字典通过键值对存储数据,每个键对应一个值。键必须是不可变类型,比如数字、字符串或元组,而值则可以是任意的数据类型。
- 可变性:字典是可变的,这意味着你可以随时添加、删除或者修改字典中的键值对。
- 无序性:在Python 3.7之前,字典是无序的。这意味着,字典中的数据项是无序排列的,你每次遍历字典时,键值对的排列顺序可能都不同。从Python 3.7开始,字典被设计为按照插入的顺序排序。
- 动态性:字典可以在运行时动态地增减,这让字典成为了处理动态数据的强大工具。
1.完整的方法列表
2.常见的操作示例
字典的创建和初始化
# 使用大括号创建空字典
empty_dict = {}
# 使用dict()函数创建空字典
empty_dict = dict()
# 直接使用键值对初始化字典,键和值之间用冒号分隔
person = {"name": "张三", "age": 30, "city": "北京"}
# 使用关键字参数初始化字典
person = dict(name="张三", age=30, city="北京")
# 通过元组列表初始化字典
person_via_tuples = dict([("name", "张三"), ("age", 30), ("city", "北京")])
访问元素
# 使用键直接访问,如果键不存在,会抛出KeyError异常
name = person["name"]
# 使用get方法安全访问,如果键不存在,会返回默认值None(可修改为其他值)
name = person.get("name") # 如果键name不存在,返回None
name = person.get("name", default="nobody") # 如果键name不存在,返回nobody
# 使用setdefault方法安全访问,如果键不存在,会返回默认值None(可修改为其他值),同时添加默认值到字典中
name = person.setdefault("name")
name = person.setdefault("name", default="nobody")
# 返回字典所有键的视图,可遍历或转换为其他容器类型如列表
person.keys()
list(person.keys()) # ["name", "age", "city"]
# 返回字典所有值的视图,可遍历或转换为其他容器类型如列表
person.values()
list(person.values()) # ["张三", 30, "北京"]
# 返回字典所有键值对的视图,可遍历或转换为其他容器类型如列表
person.items()
list(person.items()) # [("name", "张三"), ("age", 30), ("city", "北京")]
添加和修改元素
# 使用赋值语句添加或修改,键不存在时添加,键存在时修改
person["gender"] = "男"
person["age"] = 31
# 使用update方法添加或修改,键不存在时添加,键存在时修改
person.update({"gender": "男", "age": 31})
删除元素
# 使用del直接删除元素,没有返回
del person["age"]
# 使用pop方法
age = person.pop("age") # 默认如果键不存在或抛出异常
age = person.pop("age", None) # 可选设置键不存在时返回默认值,如此处的None
遍历字典
# 遍历字典,默认就是遍历键
for key in person:
print(key)
# 遍历键
for key in person.keys():
print(key)
# 遍历值
for value in person.values():
print(value)
# 遍历键值对
for key, value in person.items():
print(f"{key}: {value}")
字典推导式
一种从其他迭代器创建字典的简洁且高效的方法,借鉴了列表推导式的语法。键值对可以是任意表达式,通常是对已有的字典或任何可迭代对象进行操作和处理的结果。
# 将原字典的键和值互换
inverted_person = {value: key for key, value in person.items()}
嵌套字典
# 创建嵌套字典
employees = {
'张三': {
'职位': '项目经理',
'年龄': 30
},
'李四': {
'职位': '开发工程师',
'年龄': 25
}
}
# 访问嵌套字典
employees['张三']['职位'] # 项目经理
3.字典的性能
- 性能本来就高!:字典在Python中是通过哈希表实现的,这意味着在理想条件下,无论字典中有多少项,查找、插入和删除操作的时间复杂度都是O(1)。这使得字典成为存储和访问数据的极其高效的结构。
- 还想进一步提高?
- 尽量在创建字典时就确定好其结构和大小,避免频繁地添加或删除键值对,以减少内存的重新分配。
- 当键是简单的数据类型时,如字符串或数字,字典的性能最优。
- 利用字典方法,如get()和setdefault(),可以避免不必要的键查找和错误处理,从而提高代码的效率。
4.结语
掌握Python字典的操作不仅能帮助你高效地管理和操作数据,还能使你的代码更加简洁和优雅。
欢迎点赞收藏评论加关注,每天学习一点Python小知识,无论基础、模块、数据分析、深度学习和Ai,总有你感兴趣的。我是钢铁老豆,一个30岁转行IT、自学成为算法工程师、想用Ai点亮孩子小小世界的Pythoner。