【Python】普通字典的定义和使用方式

相关链接:【Python】顺序字典(OrderedDict)的定义和使用方式
相关链接:【Python】items()方法的介绍和使用方式
相关链接:【Python】get()方法的介绍和使用方式

在 Python 中,普通字典(通常简称为字典)是一种内置的数据类型,用于存储键值对。字典的键必须是不可变类型(如字符串、数字或元组),而值可以是任意的数据类型。字典是无序的(Python 3.6 以前),但从 Python 3.7 起,字典维护了插入顺序。这使得字典不仅是一种非常灵活的数据结构,还能够在某些应用场景下替代 OrderedDict

定义普通字典的几种方式:

1. 直接使用花括号 {}
python 复制代码
# 空字典
empty_dict = {}

# 带有键值对的字典
person = {'name': 'Alice', 'age': 25, 'city': 'New York'}
print(person)  # 输出: {'name': 'Alice', 'age': 25, 'city': 'New York'}
2. 使用字典推导式

这是一种通过迭代表达式来创建字典的方式,类似于列表推导式。

python 复制代码
# 基于一组键和一些操作来创建字典
squares = {x: x*x for x in range(6)}
print(squares)  # 输出: {0: 0, 1: 1, 2: 4, 3: 9, 4: 16, 5: 25}
3. 使用构造函数 dict()

可以使用多种方式通过 dict() 构造函数来创建字典:

python 复制代码
# 使用关键字参数
person = dict(name='Alice', age=25, city='New York')
print(person)  # 输出: {'name': 'Alice', 'age': 25, 'city': 'New York'}

# 使用键值对序列
pairs = [('name', 'Bob'), ('age', 30), ('city', 'Paris')]
person = dict(pairs)
print(person)  # 输出: {'name': 'Bob', 'age': 30, 'city': 'Paris'}

# 使用两个并行的序列
keys = ['name', 'age', 'city']
values = ['Carol', 22, 'London']
person = dict(zip(keys, values))
print(person)  # 输出: {'name': 'Carol', 'age': 22, 'city': 'London'}

访问和操作字典

字典的操作非常直接,包括访问、修改、添加和删除元素:

python 复制代码
# 访问
print(person['name'])  # 输出: Carol

# 修改
person['age'] = 23

# 添加新键值对
person['profession'] = 'Designer'

# 删除键值对
del person['city']
print(person)  # 输出: {'name': 'Carol', 'age': 23, 'profession': 'Designer'}

字典方法

Python 字典提供了丰富的方法,如 .keys(), .values(), .items(), .get(), .setdefault(), .update() 等,用于更复杂的字典操作。

总结

Python 字典是一种极其有用和灵活的数据结构,适用于需要键值映射的多种应用场景。自 Python 3.7 起,字典维护键的插入顺序,这增加了它的用途,使其在很多情况下能够取代 OrderedDict。对于绝大多数日常编程任务来说,普通字典已经足够使用。

相关推荐
ZC跨境爬虫几秒前
Scrapy实战爬取5sing网站:Pipeline优化+全流程踩坑复盘,从报错到数据落地
前端·爬虫·python·scrapy
ZhuNian的学习乐园1 分钟前
LLM智能体调度:从ReAct到多智能体调度
人工智能·python·深度学习
喵叔哟3 分钟前
6.【.NET10 实战--孢子记账--产品智能化】--认证与安全包
python·安全·flask
小鱼~~10 分钟前
Jupyter Notebook 最常用快捷键
python·jupyter
xianluohuanxiang15 分钟前
高精度气象:极端天气一来,零售最先出问题的不是客流,而是补货体系和损失控制
开发语言·人工智能·深度学习·机器学习·零售
KKKlucifer16 分钟前
零信任融合 4A 平台,构建全域身份动态可信管控体系
开发语言·php
一叶飘零_sweeeet17 分钟前
击穿 MySQL 性能天花板:InnoDB Buffer Pool 核心架构、LRU 优化与生产调优全解
数据库·mysql
indexsunny18 分钟前
互联网大厂Java面试实战:从Spring Boot到微服务架构的深度探讨
java·数据库·spring boot·安全·微服务·监控·面试实战
一叶飘零_sweeeet19 分钟前
MySQL InnoDB 锁机制全解:行锁 / 表锁 / 间隙锁 / 临键锁底层逻辑与死锁避坑指南
数据库·mysql
wgzrmlrm7420 分钟前
如何从SQL中提取年份或月份:EXTRACT与日期函数用法
jvm·数据库·python