百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

python中必须掌握的20个核心函数——list()/dict()/set()

liuian 2025-09-29 07:21 34 浏览

以下是Python中list()、dict()和set()三大核心容器函数的全面对比解析,涵盖创建方式、特性差异、应用场景及性能考量:

一、核心概念对比

特性

list()

dict()

set()

数据结构

有序可变序列

键值对映射

无序唯一元素集合

元素要求

任意类型

键必须可哈希(不可变类型)

元素必须可哈希

空对象创建

list() 或 []

dict() 或 {}

set()({}是字典)

重复元素

允许

键唯一,值可重复

自动去重

查询效率

O(n)

O(1)(键查询)

O(1)(成员检测)


二、创建方式对比

1. 空容器创建

empty_list = list()    # 或 []
empty_dict = dict()    # 或 {}
empty_set = set()      # 注意:{}创建的是空字典

2. 从可迭代对象创建

# list() - 保留所有元素
list("abc")            # ['a', 'b', 'c']
list(range(3))         # [0, 1, 2]

# dict() - 根据输入类型处理
dict([('a',1),('b',2)]) # {'a':1, 'b':2}
dict(zip(['a','b'], [1,2])) # {'a':1, 'b':2}

# set() - 自动去重
set("hello")           # {'h', 'e', 'l', 'o'}
set([1,2,2,3])         # {1, 2, 3}

3. 特殊初始化方式

# 列表推导式
[x*2 for x in range(3)] # [0, 2, 4]

# 字典推导式
{x: x**2 for x in range(3)} # {0:0, 1:1, 2:4}

# 集合推导式
{x%3 for x in range(10)} # {0, 1, 2}

三、核心操作对比

1. 增删改查

# List - 基于索引
lst = [1, 2]
lst.append(3)          # [1, 2, 3]
lst[1] = 99            # [1, 99, 3]

# Dict - 基于键
d = {'a':1}
d['b'] = 2             # {'a':1, 'b':2}
del d['a']             # {'b':2}

# Set - 基于元素
s = {1, 2}
s.add(3)               # {1, 2, 3}
s.discard(2)           # {1, 3}

2. 成员检测效率

# 示例:处理有序数据
timestamps = [1630000000, 1630000001, 1630000001]

2.dict()适用场景

  • 键值映射(如配置信息)
  • 快速查找表(如缓存)
  • 统计频次(如词频统计)
# 示例:词频统计
text = "apple banana apple"
counts = {}
for word in text.split():
    counts[word] = counts.get(word, 0) + 1
# {'apple':2, 'banana':1}

3.set()适用场景

  • 去重(如用户ID处理)
  • 集合运算(如共同好友)
  • 快速成员检测(如屏蔽词过滤)
# 示例:查找共同元素
admins = {"Alice", "Bob"}
online_users = {"Bob", "Charlie"}
admins_online = admins & online_users  # {'Bob'}

五、性能优化技巧

  1. 预分配空间
# List
lst = [None] * 1000  # 预分配比append快

# Dict
d = dict.fromkeys(range(1000))  # 快速初始化

选择合适容器

  • 频繁查询 → set/dict
  • 需要顺序 → list/OrderedDict

批量操作

# 比循环add更快
s.update([4,5,6])
d.update({'c':3, 'd':4})

六、互相转换

# List → Set(去重)
unique = set([1,2,2,3])  # {1,2,3}

# Dict → List(获取键/值)
keys = list({'a':1, 'b':2})  # ['a','b']

# Set → List
lst = list({1,2,3})  # [1,2,3](顺序不保证)

七、总结决策表

需求

推荐容器

理由

保持顺序,允许重复

list

有序索引访问

键值映射,快速查找

dict

O(1)键查询

去重,集合运算

set

自动去重,高效成员检测

内存敏感的大型数据集

set/dict

哈希表存储更节省空间

掌握这三种容器的特性差异,能够帮助您:

  • 根据场景选择最优数据结构
  • 编写更高效的Python代码
  • 合理解决去重、查找、排序等问题
  • 优化程序内存和计算性能

相关推荐

路由器组网具体连接方法(路由器组网教程)

举例:你正在用一个TP-LINK的无线路由器上网,信号不是太好,你想在下边再连一个无线路由器的话,就得在第二个路由器上设置了,先不管第一个路由器,设置步骤:把第二个无线路由器连接到电脑上(只是路...

雨林木风win7纯净版gho(雨林木风win7官网)

雨林木风WIN7光盘重装系统的步骤是将光盘放入光驱内,设置光驱为第一启动盘,打开电脑后进入光盘引导,最后将系统文件镜像到系统盘上1.你下载的雨林木风GHOSTXPSP3纯净版Y8.0是一个克隆光...

电脑一直正在重新启动怎么解决

1、电脑误删除或者是破坏了系统文件。那么需要重新安装系统。2、可能是安装的软件或者是插件跟系统兼容性冲突导致的。可以强制关机3次,然后重新启动电脑会出现恢复界面——选择安全模式——然后电脑会重新启...

如何下载ps软件免费版(ps如何下载免费版本)
如何下载ps软件免费版(ps如何下载免费版本)

1.在搜索引擎中输入adobe并点击搜索。2.点击adobe官网。3.点击支持并点击下载与安装。4.点击开始免费试用并点击下载。5.打开文件夹并点击打开进行安装即可。6.根据以上步骤即可下载安装ps。AdobePhotoshopCS6号...

2026-01-14 05:37 liuian

怎么判断该换硅脂了(cpu硅脂干了影响真的很大吗)

方法步骤如下第一,从系统软件的运行上来看,如果在运行某些大型软件,容易导致显卡发热的程序时,出现画面掉帧,或卡顿,甚至是画面卡死等情况,这大多是因为显卡散热出现问题,导致显卡自动降频,以降低功耗来减少...

壁纸图片2025最新款(电脑桌面壁纸图片2025最新款)

要更换2023最新款壁纸图片,可以按照以下步骤操作:首先,找到您想要更换的壁纸图片并下载到您的设备上。其次,进入您的设备设置,找到“壁纸”或“桌面壁纸”选项,并点击进入。然后,选择“更换壁纸”并在相册...

清理垃圾的神器(清理垃圾的神器是什么)

1、《腾讯手机管家》这款可以帮助用户进行强力的清理,加速告别空间卡顿,缓慢延迟的问题的软件当中,用户可以随时随地登录软件进行自动清理和自动清理,自动清理包括图片,视频,语音文件在内的各种换成文件,为手...

苹果笔记本怎样重装系统(苹果笔记本怎样重装系统还原)

苹果笔记本电脑系统可以通过以下步骤进行重装:1.备份数据:在开始重装前,需要备份你的重要数据。你可以将数据存储到外部硬盘、云存储或其他可靠的设备中。2.下载安装器:从AppStore中下载macOS...

手机wifi打不开怎么办

手机wifi打不开的原因,可能集中在该手机出现了手机文件丢失、手机版本不稳定、手机文件出错以及手机wifi模块摔坏等故障造成的。手机wifi打不开修复教程1.wcnss_qcom_cfg文件丢失导...

bios恢复出厂设置后无法开机

可通过进入BIOS界面设置bios恢复出厂设置的方法解决,步骤如下:1、通过按Delete或数字键盘中的Del键进入BIOS。2、按箭头键输入并将光标移动到“加载设置默认值”项,然后按enter确认。...

电脑硬盘打不开怎么办(电脑硬盘打不开怎么办)

电脑硬盘坏了是不能开机的。硬盘坏道的修复方法:1、逻辑坏道的修复对于逻辑坏道,Windows自带的“磁盘扫描程序(Scandisk)”就是最简便常用的解决手段。如果硬盘出现了坏道,我们可在Window...

linux系统备份与还原工具(linux系统备份与还原工具在哪)

用GHOST对LINUX系统做备份1:要求将安装了LINUX系统的硬盘(原盘)整盘刻至另一硬盘(目标盘)。2:所需工具:DOS系统引导盘,GHOST2003(版本低的对文件格式不能很好的支持),原盘(...

pdf怎么转换成xml格式(如何将pdf格式转换成xml格式)

将PDF转换为XML需要使用专业的PDF转换工具。以下是一些常用的PDF转XML工具:1.AdobeAcrobatDC:AdobeAcrobatDC是一款功能强大的PDF编辑软件,其中包括P...

windows7iso文件(iso文件 win7)

利用winrar可以直接打开iso文件,如果双击不能直接打开需要设置winrar,步骤如下:1、启动winrar,点击选项菜单设置命令;2、点击综合选项卡,点击全部选择,点击确定即可。具体操作方法步骤...

路由器ip地址是什么意思(路由器的ip地址是)

路由器IP地址是指连接到互联网的路由器在局域网内的唯一标识符,一般为192.168.1.1或192.168.0.1等地址。通过路由器IP地址,用户可以通过浏览器等工具登录到路由器管理界面,进行网络设置...