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

Python之--字典

定义

字典(dict)是一种无序、可变且可哈希的数据结构,字典是根据一个信息来查找另一个信息,它表示索引用的键和对应的值构成的成对关系。

特点

(1)字典与列表一样,是Python里面的可变数据类型

(2)必须唯一且不可变(如字符串、数字、元组),可以是任意类型。

(3)有无序性。

(4)基于哈希表实现,支持高效查找,查找插入和删除操作的时间复杂度接近 O (1)。

字典的创建方式

一、使用 {} 直接创建字典

语法格式:

d = {key1: value1, key2: value2, ...}  

1、用大括号 { } 包裹键值对(key: value 形式),多个键值对用逗号 , 分隔。
2、键(key):必须是不可变类型(如字符串、数字、元组),且字典内键唯一;
3、值(value):可以是任意 Python 数据类型(字符串、数字、列表、字典等都行)。

示例: 

# 直接用 {} 定义字典,存储学生信息  
student = {"name": "小明",   # 键 "name" 是字符串,值 "小明" 是字符串  "age": 15,       # 键 "age" 是字符串,值 15 是整数  "hobbies": ["篮球", "音乐"]  # 键 "hobbies" 是字符串,值是列表  
}  print(student)  
# 输出: {'name': '小明', 'age': 15, 'hobbies': ['篮球', '音乐']}  

 二、用内置函数 dict() 创建字典

1. 直接传 key=value 形式参数

语法格式:

d = dict(key1=value1, key2=value2, ...)  

说明:

(1)括号里用 key=value 形式传参(类似函数传参),Python 会自动把这些参数转为字典的键值对.

(2)这里的 key 不用加引号(本质是参数名),但实际存到字典里会变成字符串类型的键。 

 示例:

# 用 dict() + key=value 形式创建字典  
person = dict(name="小红", age=20, city="北京")  print(person)  
# 输出: {'name': '小红', 'age': 20, 'city': '北京'}  

 2. 结合 zip() 映射创建字典(“通过映射函数创建” 本质就是这用法)

语法格式:

# 先用 zip(lst1, lst2) 把两个列表 “配对”,再用 dict() 转成字典  
d = dict(zip(lst1, lst2))  

(1)zip(lst1, lst2):把两个列表 对应位置的元素 打包成元组,返回一个可迭代的 zip 对象。比如 lst1 = [10,20]、lst2 = ["cat","bar"],zip 后会得到 (10, 'cat'), (20, 'bar')。

(2)dict() 会把这些元组里的 第一个元素当键、第二个元素当值,最终转成字典。 

示例:

lst1 = [10, 20, 30, 40]  
lst2 = ["cat", "bar", "zoo", "pat"]  # 1. 用 zip 配对两个列表  
zipped = zip(lst1, lst2)  
# 此时 zipped 是可迭代对象,内容类似: (10, 'cat'), (20, 'bar'), (30, 'zoo'), (40, 'pat')  # 2. 用 dict() 转成字典  
result = dict(zipped)  print(result)  
# 输出: {10: 'cat', 20: 'bar', 30: 'zoo', 40: 'pat'}  

 **重点:

(1)lst1 里的元素会作为字典的 键,必须保证不可变且唯一(如果 lst1 有重复元素,后面的会覆盖前面的)。

(2)lst2 里的元素是字典的 值,类型无限制。

(3)如果两个列表长度不一致,zip 会以 较短的列表为准,多余元素会被忽略。

字典的访问

1、使用 d[key]

通过键直接访问对应的值。

缺点:如果键不存在,会抛出 KeyError 异常。

print(d['hello'])  # 输出: 10
# print(d['java'])  # 报错: KeyError: 'java'

2、使用 d.get(key, default=None)

通过键获取值,若键不存在则返回默认值(默认为 None)。

优点:避免 KeyError,增强代码健壮性。 

print(d.get('hello'))        # 输出: 10
print(d.get('java'))         # 输出: None(默认值)
print(d.get('java', '不存在'))  # 输出: '不存在'(自定义默认值)

 

字典的遍历

1、使用字典(Dictionary)类型的一个内置方法 items()

语法格式

dict.items()

dict 表示一个具体的字典对象,比如 my_dict = {'key1': 'value1', 'key2': 'value2'},my_dict.items()的 my_dict 就是字典对象。items() 方法会返回一个包含字典所有键值对的视图对象(dict_items类型),这个视图对象是可迭代的,其中每个元素都是一个由键和值组成的元组

my_dict = {'name': 'Alice', 'age': 25, 'city': 'New York'}
result = my_dict.items()
print(result)
# 输出: dict_items([('name', 'Alice'), ('age', 25), ('city', 'New York')])

items() 方法通常h结合循环使用

# 字典的遍历
for item in d.items():print(item)  # key=value组成的一个元素

 

2、解包遍历(分别获取 key 和 value ) 
# 在使用for循环遍历时,分别获取key,value
for key, value in d.items():print(key, value)

 

字典的一些相关操作

字典的方法描述说明
d.keys()获取所有的 key 数据
d.values()获取所有的 value 数据
d.pop(key,default)key 存在获取相应的 value,同时删除 key - value 对,否则获取默认值
d.popitem()随机从字典中取出一个 key - value 对,结果为元组类型,同时将该 key - value 从字典中删除
d.clear()清空字典中所有的 key - value 对

示例

my_dict = {'name': '小明', 'age': 18, 'city': '北京'}# 1、d.keys():获取所有的 key 数据keys = my_dict.keys()
print(keys)
# 输出(Python 3 中返回可迭代的 dict_keys 对象,便于遍历等操作 ):
# dict_keys(['name', 'age', 'city'])
# 可转成列表直观查看
print(list(keys))  
# 输出: ['name', 'age', 'city']# 2、d.values():获取所有的 value 数据values = my_dict.values()
print(values)
# 输出(返回 dict_values 对象 ):
# dict_values(['小明', 18, '北京'])
# 转列表
print(list(values))  
# 输出: ['小明', 18, '北京']# 3、d.pop(key, default):根据 key 获取 value 并删除键值对,不存在则用默认值# key 存在的情况
age_value = my_dict.pop('age', '默认值')
print(age_value)  
# 输出: 18 ,同时 my_dict 里的 'age': 18 被删除
print(my_dict)  
# 输出: {'name': '小明', 'city': '北京'}
# key 不存在的情况
gender_value = my_dict.pop('gender', '未知')
print(gender_value)  
# 输出: '未知' ,因为字典里没有 'gender' 这个 key# 4、d.popitem():随机取出一个 key - value 对(Python 3.7+ 后默认按插入顺序,逆序弹出 )item = my_dict.popitem()
print(item)  
# 比如可能输出 ('city', '北京') ,具体取决于字典当前状态,弹出后该键值对从字典删除
print(my_dict)  
# 弹出后字典内容如: {'name': '小明'} # 5、d.clear():清空字典所有 key - value 对my_dict.clear()
print(my_dict)  
# 输出: {} ,字典变成空字典

字典生成式

1、借助 range 构建简单映射(需明确 key、value 逻辑)
# 示例:用 range 生成字典,这里假设 key 是数字,value 是其平方(可按需改 key:value 逻辑)
d = {item: item**2 for item in range(5)}  
print(d)
# 输出: {0: 0, 1: 1, 2: 4, 3: 9, 4: 16}

item 来自 range 遍历,key:value 是自定义的映射规则(比如示例里 item 做 key,item**2 做 value ) 

2、用 zip 关联两个列表生成字典(适合数据配对场景)
lst1 = ['a', 'b', 'c']
lst2 = [1, 2, 3]
d = {key: value for key, value in zip(lst1, lst2)}  
print(d)
# 输出: {'a': 1, 'b': 2, 'c': 3}

利用 zip(lst1, lst2) 把两个列表对应位置元素打包成元组,遍历元组时拆出 key(来自 lst1 )和 value(来自 lst2 )构建字典 。

关于字典的内容就到这里啦~~

感谢观看!! 

 

http://www.dtcms.com/a/297217.html

相关文章:

  • CMake进阶: 检查函数/符号存在性、检查类型/关键字/表达式有效性和检查编译器特性
  • LP-MSPM0G3507学习--11ADC之二双通道高速DMA采样
  • rtpengine的docker化
  • Linux进程信号——信号保存
  • 在幸狐RV1106板子上用gcc14.2本地编译安装ssh客户端/服务器、vim编辑器、sl和vsftpd服务器
  • OSI 七层模型和五层模型
  • Vue3 学习教程,从入门到精通,Vue3 监听属性(Watchers)语法知识点及案例代码(16)
  • Unity编辑器拓展 IMGUI与部分Utility知识总结(代码+思维导图)
  • JAVA-09(2025.07.25学习记录)
  • MMRotate ReDet ReFPN 报错 `assert input.type == self.in_type`
  • Franky — 边缘计算智能语音助手 / Edge‑Computing Smart Voice Assistant
  • 04-netty基础-Reactor三种模型
  • docker compose xtify-music-web
  • 华为OpenStack架构学习9篇 连载—— 02 OpenStack界面管理【附全文阅读】
  • VR 三维重建:重塑建筑工程全生命周期的数字化革命
  • [NLP]多电源域设计的仿真验证方法
  • Redis 5.0.14安装教程
  • Android 10.0 sts CtsSecurityBulletinHostTestCases的相关异常分析
  • 关于自定义域和 GitHub Pages(Windows)
  • OpenCV(04)梯度处理,边缘检测,绘制轮廓,凸包特征检测,轮廓特征查找
  • [python][flask]Flask-Login 使用详解
  • uniapp小程序上传图片并压缩
  • 吊汤:厨房的鲜味密码
  • 若依框架 ---一套快速开发平台
  • STM32-中断配置教程(寄存器版)
  • 【应急响应】进程隐藏技术与检测方式(二)
  • Gin 框架的中间件机制
  • 三种深度学习模型(GRU、CNN-GRU、贝叶斯优化的CNN-GRU/BO-CNN-GRU)对北半球光伏数据进行时间序列预测
  • win11 使用adb 获取安卓系统日志
  • ESP32学习笔记_Peripherals(4)——MCPWM基础使用