Python列表、元组、字典和集合_python中的列表元组和字典
liuian 2025-10-14 01:05 49 浏览
Python 中的列表(List)、元组(Tuple)、字典(Dict)和集合(Set)是四种最常用的核心数据结构。掌握它们的基础操作只是第一步,真正发挥威力的是那些高级用法和技巧。
首先我们先看一下这4种类型的详细对比,确定我们在开发的时候怎么选择使用哪一种类型。
数据结构 | 是否可变 | 是否有序 | 元素是否唯一 | 查找效率 | 内存结构 | 典型应用 |
列表 (List) | 可变 | 有序 | 允许重复 | O(n) | 动态指针数组 | 动态有序数据 |
元组 (Tuple) | 不可变 | 有序 | 允许重复 | O(n) | 静态指针数组 | 不变数据,作字典键 |
字典 (Dict) | 可变 | 插入序 | Key唯一 | O(1) | 哈希表 | 键值映射,快速查找 |
集合 (Set) | 可变 | 无序 | 元素唯一 | O(1) | 哈希表(仅键) | 去重,集合运算 |
总结与选择建议:
- 需要存储一个有序且可能变化的序列吗? -> 选择 列表。
- 需要存储一组不可变的、作为键或保证安全的数据吗? -> 选择 元组。
- 需要通过唯一的键来快速查找和关联值吗? -> 选择 字典。
- 需要保证元素的唯一性,或进行集合运算(如去重、求交集并集)吗? -> 选择 集合。
列表 (List) 的高级用法
列表的强大远超基础的增删改查。
- 列表推导式 (List Comprehension)。
这是编写 Pythonic 代码的利器,它用简洁的语法快速生成新列表
# 基础:快速生成平方数列表
squares = [x**2 for x in range(10)]# [0, 1, 4, 9, ..., 81]
# 带条件过滤:生成偶数的平方
even_squares = [x**2 for x in range(10) if x % 2 == 0]# [0, 4, 16, 36, 64]
# 多重循环:模拟嵌套循环,生成全排列
pairs = [(x, y) for x in ['A', 'B'] for y in [1, 2]]
# 结果: [('A', 1), ('A', 2), ('B', 1), ('B', 2)]- 切片赋值与高级切片。
切片不仅可以取数据,还可以批量修改、删除甚至插入数据
my_list = [1, 2, 3, 4, 5]
# 批量替换子序列 my_list[1:4] = [20, 30, 40]# my_list 变为 [1, 20, 30, 40, 5]
# 批量删除子序列 (用空列表替换) my_list[1:4] = []# my_list 变为 [1, 5]
# 使用步长进行间隔替换(数量必须匹配) my_list[::2] = [100, 200]# 将第1、3个元素替换为100, 200- 与 map, filter, zip等函数式工具结合
这些内置函数让列表处理更高效和声明式。
numbers = ['1', '2', '3']
# map: 将函数应用于列表每个元素 int_list = list(map(int, numbers)) # [1, 2, 3]
# filter: 过滤列表中满足条件的元素 even_list = list(filter(lambda x: x % 2 == 0, [1,2,3,4])) # [2, 4]
# zip: 将多个列表对应位置的元素"打包"成元组
names = ['Alice', 'Bob']
scores = [85, 92]
zipped = list(zip(names, scores)) # [('Alice', 85), ('Bob', 92)]
# 用zip优雅地同步遍历多个列表
for name, score in zip(names, scores):
print(f"{name}: {score}")- 性能注意事项
- 列表在尾部进行 append和 pop操作很快(O(1)时间复杂度)。
- 在头部或中部进行 insert或 pop操作可能较慢(O(n)时间复杂度),因为需要移动后续元素。
- 对于需要频繁在两端进行添加或删除操作的场景,可以考虑使用 collections.deque(双端队列),它在队列两端都有出色的性能表现。
元组 (Tuple) 的高级用法
元组的“不可变性”是其核心优势,带来了安全、高效和可哈希的特性。
- 解包 (Unpacking)。
这是元组最优雅的特性之一,可以一次性将元组元素赋值给多个变量
# 基本解包
point = (10, 20)
x, y = point# x=10, y=20
# 使用 * 进行可变长度解包 (Python 3)
numbers = (1, 2, 3, 4, 5)
first, *middle, last = numbers# first=1, middle=[2,3,4], last=5
a, *b, c, d = numbers# a=1, b=[2,3], c=4, d=5
# 在循环中解包
for name, score in zipped:# 接上文zip的例子
print(f"{name}'s score is {score}")
# 使用下划线 _ 忽略不需要的值
name, _, salary = ("Alice", "Engineer", 50000) # 忽略职位- 作为字典的键或集合的元素。
由于元组是不可变的、可哈希的,它可以作为字典的键,这是列表无法做到的
# 用元组表示坐标,作为字典的键
location_map = {
(40.7128, -74.0060): "New York",
(34.0522, -118.2437): "Los Angeles"
}
print(location_map[(40.7128, -74.0060)])# 输出: New York
# 元组也可以放入集合中(需确保所有元素都可哈希)
unique_points = {(1, 2), (3, 4), (1, 2)} # {(1, 2), (3, 4)}- 命名元组 (Named Tuple)。
collections.namedtuple让元组不仅有序号,还有了名字,极大提升了代码的可读性
from collections import namedtuple
# 定义一个命名元组类型 'Person'
Person = namedtuple('Person', ['name', 'age', 'job'])
# 创建命名元组实例
alice = Person(name="Alice", age=30, job="Engineer")
# 通过字段名访问,意义明确
print(alice.name) # Alice
print(alice.job) # Engineer
# 仍然支持索引访问
print(alice[0]) # Alice- 函数返回多个值。
本质上,Python 函数返回多个值就是返回一个元组
def calculate_stats(data):
total = sum(data)
count = len(data)
average = total / count return total, count, average # 返回一个元组 (total, count, average)
# 接收返回值时常用解包
total, count, avg = calculate_stats([1, 2, 3, 4, 5])字典 (Dict) 的高级用法
字典的核心在于基于键的快速查找(O(1)平均时间复杂度)。
- 字典推导式 (Dict Comprehension)。
与列表推导式类似,可以快速简洁地创建字典
# 快速创建键值对
squares = {x: x*x for x in range(5)}# {0: 0, 1: 1, 2: 4, 3: 9, 4: 16}
# 交换键和值(前提是值都是可哈希的)
original = {'a': 1, 'b': 2}
swapped = {v: k for k, v in original.items()}# {1: 'a', 2: 'b'}
# 带条件的推导式
even_squares = {x: x*x for x in range(10) if x % 2 == 0}- setdefault和 get方法安全访问
这些方法可以优雅地处理键可能不存在的情况,避免 KeyError。
my_dict = {'name': 'Alice', 'age': 30}
# get(key, default): 键不存在时返回默认值,不会引发异常
job = my_dict.get('job', 'Unemployed')# 'Unemployed'
age = my_dict.get('age')# 30
# setdefault(key, default): 键不存在时,设置键值并返回默认值;键存在则返回对应的值
# 常用于初始化列表、集合等值,避免重复判断
data = {}
for item in ['A', 'B', 'A', 'C']:
# 如果键不存在,将键对应的值初始化为空列表,然后追加元素
data.setdefault(item, []).append(f"Value_{item}")
# data: {'A': ['Value_A', 'Value_A'], 'B': ['Value_B'], 'C': ['Value_C']}- 字典合并 (Merging Dictionaries)
有多种方式可以将多个字典合并为一个。
d1 = {'a': 1, 'b': 2}
d2 = {'b': 3, 'c': 4} # 注意键 'b' 重复
# 方法1: {**d1, **d2} (Python 3.5+)
merged = {**d1, **d2} # {'a': 1, 'b': 3, 'c': 4},后面的值覆盖前面的
# 方法2: d1.update(d2) (原地修改d1)
d1.update(d2) # d1 变为 {'a': 1, 'b': 3, 'c': 4}
# 方法3: collections.ChainMap (逻辑合并,不创建新字典)
from collections import ChainMap
chain = ChainMap(d1, d2) # 按顺序查找键- 使用 collections模块中的特殊字典
defaultdict: 提供默认值工厂,简化初始化。
from collections import defaultdict
# 初始化一个默认值为列表的字典 list_dict = defaultdict(list)
list_dict['fruits'].append('apple')# 无需先判断键是否存在
# 初始化一个默认值为0的字典(用于计数)
count_dict = defaultdict(int)
for word in ['apple', 'banana', 'apple']:
count_dict[word] += 1# 第一次遇到'apple'时,初始值就是0
# count_dict: defaultdict(<class 'int'>, {'apple': 2, 'banana': 1})- Counter: 专为计数设计的字典子类。
from collections import Counter
words = ['apple', 'banana', 'apple', 'orange', 'banana', 'apple']
word_count = Counter(words)
print(word_count) # Counter({'apple': 3, 'banana': 2, 'orange': 1})
print(word_count.most_common(2)) # [('apple', 3), ('banana', 2)]集合 (Set) 的高级用法
集合的核心是唯一性和数学集合操作。
- 集合推导式 (Set Comprehension)
与列表推导式类似,用于创建集合,自动去重。
# 创建一个包含平方数的集合(自动去重)
numbers = [1, 2, 2, 3, 4, 4, 4]
unique_squares = {x*x for x in numbers} # {1, 4, 9, 16}- 强大的集合运算
集合支持并集、交集、差集、对称差集等数学运算。
set_a = {1, 2, 3, 4}
set_b = {3, 4, 5, 6}
# 并集 (Union): 所有在A或B中的元素
print(set_a | set_b)# {1, 2, 3, 4, 5, 6}
print(set_a.union(set_b))# 同上
# 交集 (Intersection): 所有同时在A和B中的元素
print(set_a & set_b)# {3, 4}
print(set_a.intersection(set_b))# 同上
# 差集 (Difference): 在A中但不在B中的元素
print(set_a - set_b)# {1, 2}
print(set_a.difference(set_b))# 同上
# 对称差集 (Symmetric Difference): 在A或B中,但不同时在两者中的元素
print(set_a ^ set_b)# {1, 2, 5, 6}
print(set_a.symmetric_difference(set_b))# 同上
# 子集/超集判断
print({1, 2}.issubset(set_a)) # True
print(set_a.issuperset({1, 2})) # True- 从序列中快速去除重复项
这是集合最常用的场景之一。
my_list = [1, 2, 2, 3, 4, 4, 4, 5]
unique_list = list(set(my_list)) # [1, 2, 3, 4, 5] (顺序可能改变)
# 如果需要保持原始顺序,可以使用字典(Python 3.7+字典有序)
unique_list_ordered = list(dict.fromkeys(my_list).keys()) # [1, 2, 3, 4, 5]相关推荐
-
- 驱动网卡(怎么从新驱动网卡)
-
网卡一般是指为电脑主机提供有线无线网络功能的适配器。而网卡驱动指的就是电脑连接识别这些网卡型号的桥梁。网卡只有打上了网卡驱动才能正常使用。并不是说所有的网卡一插到电脑上面就能进行数据传输了,他都需要里面芯片组的驱动文件才能支持他进行数据传输...
-
2026-01-30 00:37 liuian
- win10更新助手装系统(微软win10更新助手)
-
1、点击首页“系统升级”的按钮,给出弹框,告诉用户需要上传IMEI码才能使用升级服务。同时给出同意和取消按钮。华为手机助手2、点击同意,则进入到“系统升级”功能华为手机助手华为手机助手3、在检测界面,...
- windows11专业版密钥最新(windows11专业版激活码永久)
-
Windows11专业版的正版密钥,我们是对windows的激活所必备的工具。该密钥我们可以通过微软商城或者通过计算机的硬件供应商去购买获得。获得了windows11专业版的正版密钥后,我...
-
- 手机删过的软件恢复(手机删除过的软件怎么恢复)
-
操作步骤:1、首先,我们需要先打开手机。然后在许多图标中找到带有[文件管理]文本的图标,然后单击“文件管理”进入页面。2、进入页面后,我们将在顶部看到一行文本:手机,最新信息,文档,视频,图片,音乐,收藏,最后是我们正在寻找的[更多],单击...
-
2026-01-29 23:55 liuian
- 一键ghost手动备份系统步骤(一键ghost 备份)
-
步骤1、首先把装有一键GHOST装系统的U盘插在电脑上,然后打开电脑马上按F2或DEL键入BIOS界面,然后就选择BOOT打USDHDD模式选择好,然后按F10键保存,电脑就会马上重启。 步骤...
- 怎么创建局域网(怎么创建局域网打游戏)
-
1、购买路由器一台。进入路由器把dhcp功能打开 2、购买一台交换机。从路由器lan端口拉出一条网线查到交换机的任意一个端口上。 3、两台以上电脑。从交换机任意端口拉出网线插到电脑上(电脑设置...
- 精灵驱动器官方下载(精灵驱动手机版下载)
-
是的。驱动精灵是一款集驱动管理和硬件检测于一体的、专业级的驱动管理和维护工具。驱动精灵为用户提供驱动备份、恢复、安装、删除、在线更新等实用功能。1、全新驱动精灵2012引擎,大幅提升硬件和驱动辨识能力...
- 一键还原系统步骤(一键还原系统有哪些)
-
1、首先需要下载安装一下Windows一键还原程序,在安装程序窗口中,点击“下一步”,弹出“用户许可协议”窗口,选择“我同意该许可协议的条款”,并点击“下一步”。 2、在弹出的“准备安装”窗口中,可...
- 电脑加速器哪个好(电脑加速器哪款好)
-
我认为pp加速器最好用,飞速土豆太懒,急速酷六根本不工作。pp加速器什么网页都加速,太任劳任怨了!以上是个人观点,具体性能请自己试。ps:我家电脑性能很好。迅游加速盒子是可以加速电脑的。因为有过之...
- 任何u盘都可以做启动盘吗(u盘必须做成启动盘才能装系统吗)
-
是的,需要注意,U盘的大小要在4G以上,最好是8G以上,因为启动盘里面需要装系统,内存小的话,不能用来安装系统。内存卡或者U盘或者移动硬盘都可以用来做启动盘安装系统。普通的U盘就可以,不过最好U盘...
- u盘怎么恢复文件(u盘文件恢复的方法)
-
开360安全卫士,点击上面的“功能大全”。点击文件恢复然后点击“数据”下的“文件恢复”功能。选择驱动接着选择需要恢复的驱动,选择接入的U盘。点击开始扫描选好就点击中间的“开始扫描”,开始扫描U盘数据。...
- 系统虚拟内存太低怎么办(系统虚拟内存占用过高什么原因)
-
1.检查系统虚拟内存使用情况,如果发现有大量的空闲内存,可以尝试释放一些不必要的进程,以释放内存空间。2.如果系统虚拟内存使用率较高,可以尝试增加系统虚拟内存的大小,以便更多的应用程序可以使用更多...
-
- 剪贴板权限设置方法(剪贴板访问权限)
-
1、首先打开iphone手机,触碰并按住单词或图像直到显示选择选项。2、其次,然后选取“拷贝”或“剪贴板”。3、勾选需要的“权限”,最后选择开启,即可完成苹果剪贴板权限设置。仅参考1.打开苹果手机设置按钮,点击【通用】。2.点击【键盘】,再...
-
2026-01-29 21:37 liuian
- 平板系统重装大师(平板重装win系统)
-
如果你的平板开不了机,但可以连接上电脑,那就能好办,楼主下载安装个平板刷机王到你的个人电脑上,然后连接你的平板,平板刷机王会自动识别你的平板,平板刷机王上有你平板的我刷机包,楼主点击下载一个,下载完成...
- 联想官网售后服务网点(联想官网售后服务热线)
-
联想3c服务中心是联想旗下的官方售后,是基于互联网O2O模式开发的全新服务平台。可以为终端用户提供多品牌手机、电脑以及其他3C类产品的维修、保养和保险服务。根据客户需求层次,联想服务针对个人及家庭客户...
- 一周热门
-
-
用什么工具在Win中查看8G大的log文件?
-
如何在 Windows 10 或 11 上通过命令行安装 Node.js 和 NPM
-
如何修改图片拍摄日期?快速修改图片拍摄日期的6种方法
-
5步搞定动态考勤表!标记节假日、调休日?Excel自动变色!
-
RK3588-HDMIRX(瑞芯微rk3588芯片手册)
-
用纯Python轻松构建Web UI:Remi 动态更新,实时刷新界面内容
-
tplink无线路由器桥接教程(tplink路由器如何进行无线桥接)
-
R语言 | CNS绘图第1款——linkET万物皆可连
-
都说Feign是RPC,没有侵入性,为什么我的代码越来越像 C++
-
windows11专业版密钥最新(windows11专业版激活码永久)
-
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)
- mysql刷新权限 (34)
