Python列表集合操作介绍? python列表和集合
liuian 2024-12-28 14:13 46 浏览
列表和集合是在Python编程中比较常用,而且比较常见的两种数据结构,他们有着各自的特点以及使用场景,下面我们就来详细的介绍一下列表和集合在实际使用中的一些操作对比。
List(列表)
列表操作的特点就是它其中的元素是有序的,并且我们可以通过它的索引来访问到列表中指定位置的元素,并且列表中的元素是可以支持重复的,列表支持了对元素的基本的增删改查操作,作为Python中的列表来讲,并没有像是Java中的列表一样存在强制的数据结构类型,它可以存放任意类型的数据,也就是说Python的列表是可以进行数据混合存储的。
列表的常见操作,如下所示。
# 定义列表
lst = [1, 2, 3, 4, 5]
# 1. 添加元素
lst.append(6) # 在列表末尾添加元素
lst.insert(2, 99) # 在索引位置 2 处插入 99
# 2. 删除元素
lst.remove(99) # 删除第一个匹配的元素 99
lst.pop() # 删除最后一个元素,并返回该元素
lst.pop(0) # 删除索引为 0 的元素
# 3. 修改元素
lst[1] = 100 # 修改索引为 1 的元素为 100
# 4. 查询元素
element = lst[0] # 获取索引为 0 的元素
index = lst.index(100) # 获取元素 100 的索引
# 5. 列表长度
length = len(lst) # 获取列表长度
# 6. 列表切片
sublist = lst[1:4] # 切片获取索引为 1 到 3 的子列表
# 7. 排序和反转
lst.sort() # 对列表进行排序
lst.reverse() # 反转列表顺序
# 8. 遍历列表
for item in lst:
print(item)
# 9. 列表拼接
lst1 = [1, 2, 3]
lst2 = [4, 5, 6]
lst_combined = lst1 + lst2 # 列表拼接
# 10. 清空列表
lst.clear() # 清空列表
Set(集合)
与列表相比,集合中的元素是无序的,也就是说不能通过某个索引的机制来去访问元素,并且集合中的元素是唯一的,也就是说集合中的数据元素是不能重复的。对于一个集合操作来讲它本身是可变的,但是其中存储的元素类型是不可变的,例如存储整数、字符串、元组等。
集合常用操作如下所示。
# 定义集合
s = {1, 2, 3, 4, 5}
# 1. 添加元素
s.add(6) # 添加元素 6
# 2. 删除元素
s.remove(5) # 删除元素 5,如果不存在会报错
s.discard(10) # 删除元素 10,如果不存在不会报错
s.pop() # 随机删除一个元素,并返回该元素
# 3. 集合运算
s1 = {1, 2, 3}
s2 = {3, 4, 5}
# 交集
intersection = s1 & s2 # {3}
intersection = s1.intersection(s2) # {3}
# 并集
union = s1 | s2 # {1, 2, 3, 4, 5}
union = s1.union(s2) # {1, 2, 3, 4, 5}
# 差集
difference = s1 - s2 # {1, 2}
difference = s1.difference(s2) # {1, 2}
# 对称差集(只在一个集合中出现的元素)
symmetric_difference = s1 ^ s2 # {1, 2, 4, 5}
symmetric_difference = s1.symmetric_difference(s2) # {1, 2, 4, 5}
# 4. 检查子集、超集关系
is_subset = s1 <= s2 # 检查 s1 是否为 s2 的子集
is_superset = s1 >= s2 # 检查 s1 是否为 s2 的超集
# 5. 集合长度
length = len(s) # 获取集合长度
# 6. 遍历集合
for item in s:
print(item)
# 7. 清空集合
s.clear() # 清空集合
列表与集合的区别
- 有序性:列表是有序的,可以通过索引访问元素;集合是无序的,不能通过索引访问元素。
- 重复元素:列表允许有重复元素;集合中的元素是唯一的,不允许重复。
- 常见场景:当需要有序、重复的数据时,使用列表;当需要无序且唯一的元素时,使用集合。
可以通过 list() 和 set() 函数在列表和集合之间进行转换,如下所示
# 列表转集合
lst = [1, 2, 2, 3, 4]
s = set(lst) # {1, 2, 3, 4}
# 集合转列表
s = {1, 2, 3, 4}
lst = list(s) # [1, 2, 3, 4] (注意,顺序可能改变)
总结
通过以上介绍,我们知道了列表和集合它们分别有各自的特点和使用场景,我们可以根据不同的需求选择使用列表或集合。
相关推荐
- Docker 47 个常见故障的原因和解决方法
-
【作者】曹如熙,具有超过十年的互联网运维及五年以上团队管理经验,多年容器云的运维,尤其在Docker和kubernetes领域非常精通。Docker是一种相对使用较简单的容器,我们可以通过以下几种方式...
- 电脑30个快问快答,解决常见电脑问题
-
1.强行关机/停电对电脑有影响吗?答:可能损坏硬盘(机械硬盘风险高)、未保存数据丢失,偶尔一次影响小,但频繁操作会缩短硬件寿命。2.C盘满影响速度吗?答:会!系统运行需C盘空间缓存临时数据,空间不...
- 使用Tcpdump包抓取分析数据包的详细用法
-
TcpDump可以将网络中传送的数据包的“头”完全截获下来提供分析。它支持针对网络层、协议、主机、网络或端口的过滤,并提供and、or、not等逻辑语句来帮助你去掉无用的信息。tcpdump就是一种...
- 电脑启动不了(BootDevice Not Found Hard Disk-3F0)解决方案
-
HP品牌机,开机启动不了,黑屏,开机取下主板电池恢复BIOS后,开机显示找不到启动盘。一、按F2键进入BIOS,出现硬盘内存检测界面的话,直接退出。就会出现这个界面,光标键向下,选择BIOSSetu...
- 电脑开机黑屏别慌!快码住!起底维修老师傅不能说的秘密
-
按下开机键却只收获黑屏大礼包?那些神秘的英文提示、刺耳的蜂鸣声,其实是电脑在给你发送求救信号!从按下电源到进入桌面的12秒里,你的电脑经历了史诗级的硬件自检与系统加载,今天我们就破译这段“摩斯电码”。...
- 电脑启动故障为何总要先看BIOS?新手必读的关键知识解析
-
最近在帮朋友们解答电脑无法正常开机的问题时,发现大家经常收到一句高频建议:“先检查BIOS”。对不少普通用户而言,BIOS依然是个神秘的存在。那么,BIOS到底是什么?电脑出现哪些故障会与它相关呢?本...
- Windows 11 KB5053598更新:安全补丁还是系统噩梦?
-
2025年3月11日,微软发布了Windows1124H2的强制性更新KB5053598,作为“周二补丁日”(PatchTuesday)的一部分。然而,这款本应提升系统安全性的更新却引发了广泛的...
- 飞牛OS入门安装遇到问题,如何解决?
-
之前小编尝试了用旧电脑装飞牛OS安装之前特意查了一些硬件要求飞牛OS目前支持主流的x86架构硬件主机需能连网线飞牛OS暂时不支持只有无线网卡的安装貌似很多小伙伴在一开始安装就卡住了那今天咱们汇总分...
- 几种常见的电脑开机黑屏显示白色英文字母解决方法
-
当电脑开机出现黑屏并显示白色英文字母时,通常表示系统启动过程中遇到了错误。以下是几种常见原因及对应的解决方法,按照排查顺序整理:一、检查外接设备与硬件连接可能原因:外接U盘、移动硬盘等未拔出,或内部硬...
- 电脑启动出现问题,为什么都要先检查BIOS?
-
【ZOL中关村在线原创技巧应用】最近在回答问题的时候,总会发现很多朋友都在问“电脑无法正常开机怎么办?”这样类似的问题,而许多DIY大佬的回复总会出现一条高频建议“先检查BIOS”。但对于许多普通用户...
- 教你怎么用JavaScript检测当前浏览器是无头浏览器
-
什么是无头浏览器(headlessbrowser)?无头浏览器是指可以在图形界面情况下运行的浏览器。我可以通过编程来控制无头浏览器自动执行各种任务,比如做测试,给网页截屏等。为什么叫“无头”浏览器?...
- 12个高效的Python爬虫框架,你用过几个?
-
实现爬虫技术的编程环境有很多种,Java、Python、C++等都可以用来爬虫。但很多人选择Python来写爬虫,为什么呢?因为Python确实很适合做爬虫,丰富的第三方库十分强大,简单几行代码便可实...
- 运维的报表之路,用 node.js 轻松发送 grafana 报表
-
在运维过程中,无论是监控还是报表,都会有一些通过邮件发送图表的需求,由于开源的zabbix,grafana和kibana等并不完全具有“想发送哪儿就发送哪儿”的图片生成功能,在grafana...
- C#基于浏览器内核的高级爬虫(c#爬取网页内容)
-
基于C#.NET+PhantomJS+Sellenium的高级网络爬虫程序。可执行Javascript代码、触发各类事件、操纵页面Dom结构、甚至可以移除不喜欢的CSS样式。很多网站都用Ajax动态加...
- 如何优化一个秒杀项目?(秒杀实现思路)
-
问题1:使用jmeter性能压测,定位瓶颈代码步骤流程:线程组--->Http请求--->查看结果树--->聚合报告tips:host的文件--->优先调用映射,减少DNS的时...
- 一周热门
-
-
Python实现人事自动打卡,再也不会被批评
-
Psutil + Flask + Pyecharts + Bootstrap 开发动态可视化系统监控
-
一个解决支持HTML/CSS/JS网页转PDF(高质量)的终极解决方案
-
【验证码逆向专栏】vaptcha 手势验证码逆向分析
-
再见Swagger UI 国人开源了一款超好用的 API 文档生成框架,真香
-
网页转成pdf文件的经验分享 网页转成pdf文件的经验分享怎么弄
-
C++ std::vector 简介
-
python使用fitz模块提取pdf中的图片
-
《人人译客》如何规划你的移动电商网站(2)
-
Jupyterhub安装教程 jupyter怎么安装包
-
- 最近发表
- 标签列表
-
- 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)
- table.render (33)
- uniapp textarea (33)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- react-admin (33)
- vscode切换git分支 (35)
- vscode美化代码 (33)
- python bytes转16进制 (35)