【Python核心数据结构探秘】:元组与字典的完美协奏曲

文章目录

      • 🚀一、元组
        • ⭐1. 元组查询的相关方法
        • ❤️2. 坑点
        • 🎬3. 修改元组
      • 🌈二、集合
        • ⭐1. 集合踩坑
        • ❤️2. 集合特点
          • 💥无序性
          • 💥唯一性
        • ☔3. 集合(交,并,补)
        • 🎬4. 集合操作方法
          • 💥💥增
          • 💥💥删
          • 💥💥(增)
          • 💥💥查

🚀一、元组

在这里插入图片描述

  • 元组:tuple
  • 元组符号:()
  • 元组属于不可变类型(不可变序列)
  • 元组是序列类型(容器序列)
  • 元组不提供方法修改,但是可以转类型进行操作
⭐1. 元组查询的相关方法
  • index 查询指定元素第一次出现的下标
tuple1 = (1, 'hah', '帅')
print(tuple1.index('帅'))  # 2

在这里插入图片描述
注意

  • 如果元组中不存在你要查找的值,index() 方法会抛出一个 ValueError 异常。

  • 由于元组是不可变的,找到索引通常是为了了解结构,而不是为了修改元组内容(因为无法修改)。

  • index() 方法只返回第一个匹配项的索引,即使该值在元组中出现了多次。

  • count 查询指定元素出现的次数

count() 方法,用于统计元组中某个元素出现的次数。

tuple.count(element)
  • tuple:你想要在其内部计数的元组。
  • element:你想要统计其出现次数的元素。
tuple2 = ('帅', 1, '帅', 'hah', '帅')
print(tuple2.count('帅'))  # 3

在这里插入图片描述

❤️2. 坑点

在Python中,元组是一种不可变的序列类型。当定义一个只包含一个元素的元组时,确实会出现一些特殊情况。如果你直接写作(元素),Python不会把它解析为一个元组,而是将其视为一个单纯的括号包围的表达式。为了明确表示这是一个只有一个元素的元组,你应该在元素后面加上一个逗号,即(元素,)。

  • 不加逗号:single_item = (42),这在Python中实际上被视为一个整数42,而不是一个元组。
  • 加逗号:single_tuple = (42,),这样就明确地定义了一个只包含一个元素42的元组。

这是因为括号()在Python中还用于表示运算优先级,以及在函数调用时包围参数列表。为了消除歧义,当创建一个只有一个元素的元组时,添加逗号是必要的。

tuple3 = (1)
print(type(tuple3))  # <class 'int'>

tuple4 = (1,)
print(type(tuple4))  # <class 'tuple'>

# 当()中只存在一个元素时, 其后没有 , 号, 那么其类型保持元素原类型
#                        有 , 号 ---- 为元组类型

在这里插入图片描述

🎬3. 修改元组
# 通过转类型的方式进行修改

tuple1 = (1, 'qwe', 'hahah')

# 结构相似的数据类型--- list
# 通过list方法直接将其强转为列表
list1 = list(tuple1)
# print(list1)  # [1, 'qwe', 'hahah']

# 操作数据
list1.append('快乐')
# print(list1)  # [1, 'qwe', 'hahah', '快乐']

# 转回列表 --- 通过tuple方法
tuple2 = tuple(list1)
print(tuple2)  # (1, 'qwe', 'hahah', '快乐')

在这里插入图片描述

🌈二、集合

  • 集合:set
  • 集合符号:{数据1,数据2…}
  • 集合属于可变类型
  • 集合数据是无序的(无序性)
  • 集合每一个元素是唯一的(唯一性)
  • 集合不属于序列
集合(set)是一种无序、不重复元素的集合,它具有判定成员资格、消除重复元素等特点。集合的元素必须是不可变的类型,例如整数、浮点数、字符串、元组等,但不能包含可变类型的对象,例如列表、字典等。集合也不是序列类型,因为它们不支持索引、切片等序列操作。
⭐1. 集合踩坑

空集合问题

set1 = {}
print(type(set1))  # &lt;class 'dict'&gt;

# 原因:集合(set)与字典(dict)符号一样,但内部数据结构不同,当为{}时,它是被识别为字典

# 因此 空集合 的创建是用 set()

set2 = set()
print(type(set2))  # <class 'set'>

在这里插入图片描述

❤️2. 集合特点
💥无序性
set1 = {'hah', 1, '快'}
print(set1)
# 多执行几次,发现数据出来顺序是乱的
# {1, 'hah', '快'}
# {'hah', 1, '快'}

在这里插入图片描述

💥唯一性
set2 = {'hah', 1, '快', 1, 1, 1}
print(set2)  # {1, '快', 'hah'}

在这里插入图片描述

☔3. 集合(交,并,补)

在这里插入图片描述

set_a = {1, 2, 'a'}
set_b = {1, 3, 'b'}

# 交集  &
set_jiao = set_a & set_b
print(set_jiao)  # {1}

# 并集  |
set_bing = set_a | set_b
print(set_bing)  # {'b', 1, 2, 3, 'a'}

# 补集  -
set_bu_b = set_a - set_b  # set_b的补集
print(set_bu_b)  # {'a', 2}
set_bu_a = set_b - set_a  # set_a的补集
print(set_bu_a)  # {'b', 3}

在这里插入图片描述

🎬4. 集合操作方法
💥💥增
  • add: 是把要传入的元素做为一个整个添加到集合中

集合(set)是一个无序的、不重复元素的序列。add() 方法是集合的一个内置方法,用于向集合中添加一个元素。如果添加的元素已经在集合中存在,则该方法不会有任何效果,因为集合的特性决定了它不能包含重复的元素。

set.add(element)
  • set:你要向其添加元素的集合。
  • element:你想要添加到集合中的元素。
set3 = {1, 'ahah', '数据'}
set3.add('shu')
print(set3) # {'ahah', 1, 'shu', '数据'}

在这里插入图片描述

💥💥删
  • pop: 删除并且返回 set “集合”中的一个不确定的元素, 如果集合为空则引发 KeyError

集合(set)的 pop() 方法用于随机移除集合中的一个元素并返回该元素。因为集合是无序的,所以无法预测哪个元素会被移除。如果集合为空,调用 pop() 方法会引发 KeyError 异常。

element = set.pop()
  • set:你要从中移除并返回一个随机元素的集合。
  • element:被移除的元素。
# 随机删
set4 = {1, 'ahah', '数据'}
set4.pop()
print(set4)  # {'ahah', '数据'}

在这里插入图片描述

  • remove:从 set “集合”中删除指定元素 , 如果不存在则引发 KeyError

集合(set)的 remove() 方法用于移除集合中指定的元素。如果元素存在于集合中,该方法会移除这个元素,并且不返回任何值。如果尝试移除一个不存在于集合中的元素,remove() 方法会引发 KeyError 异常。
语法:

set.remove(element)
  • set:你想要从中移除元素的集合。
  • element:你想要从集合中移除的指定元素。
set5 = {1, 'ahah', '数据'}
set5.remove('ahah')
print(set5)  # {1, '数据'}

set7 = {1, 'ahah', '数据'}
set7.remove('kuail')  # KeyError: 'kuail'

在这里插入图片描述

  • discard: 如果在 set “集合”中存在元素 x, 则删除 ,不存在不报错
set5 = {1, 'ahah', '数据'}
set5.discard('ahah')
print(set5)  # {1, '数据'}

set7 = {1, 'ahah', '数据'}
set7.discard('kuail')
print(set7)  # {1, 'ahah', '数据'}

在这里插入图片描述

  • clear: 清空集合里面的所有元素
set8 = {1, 'ahah', '数据'}
set8.clear()
print(set8)  # set()   --空集合
💥💥(增)
  • update:可以在集合里面添加多项
set9 = {1, 'ahah', '数据'}
set9.update([1, '2', 3, '4'])
print(set9)  # {1, 3, '4', 'ahah', '2', '数据'}

set10 = {1, 'ahah', '数据'}
set10.update('你快乐吗?')
print(set10)  # {1, '吗', '数据', 'ahah', '你', '乐', '?', '快'}

在这里插入图片描述

💥💥查
  • isdisjoint: 是否无交集(无交集:True 有交集:False)
set11 = {1, 2, 'a'}
set12 = {1, 3, 'b'}

print(set11.isdisjoint(set12))  # False
  • issubset: 判断指定集合是否为该方法参数集合的子集。 是True, 不是False
# a.issubset(b) :  集合a是否为集合b的子集   判断集合b 是否包含 集合a

set13 = {1, 2, 'a'}
set14 = {1, 3, 'b'}
set15 = {1}
print(set13.issubset(set14))  # False
print(set15.issubset(set14))  # True
  • issuperset : 判断该方法的参数集合是否为指定集合的子集
# a.issuperset(b) :  集合b是否为集合a的子集   判断集合a 是否包含 集合b

set13 = {1, 2, 'a'}
set14 = {1, 3, 'b'}
set15 = {1}
print(set13.issuperset(set14))  # False
print(set15.issuperset(set14))  # False
print(set14.issuperset(set15))  # True

在这里插入图片描述

  • intersection: 返回集合的交集
set16 = {1, 2, 'a'}
set17 = {1, 3, 'b'}

print(set16.intersection(set17))  # {1}
  • intersection_update: 移除 指定集合 中不存在于 方法中的接收集合 中的元素(修改当前集合,使其只包含与另一个指定集合相同的元素。)
set16 = {1, 2, 'a'}
set17 = {1, 3, 'b'}
# 移除 set16 中不存在于 set17 中的元素
set16.intersection_update(set17)
print(set16)  # {1}
print(set17)  # {1, 3, 'b'}

# 使用 intersection_update() 方法同时获取多个集合的交集,并修改 set1
set1 = {1, 2, 3, 4, 5}
set2 = {4, 5, 6, 7}
set3 = {3, 4, 5}
set4 = {1, 3, 5}
set1.intersection_update(set2, set3, set4)
print(set1)      # 输出结果为 {5}

在这里插入图片描述

  • symmetric_difference: 返回两个集合中不重复的元素集合。
set18 = {1, 2, 'a'}
set19 = {1, 3, 'b'}

print(set18.symmetric_difference(set19))  # {2, 3, 'b', 'a'}

在这里插入图片描述

  • symmetric_difference_update: 用于修改当前集合,使其只包含存在于当前集合或另一个指定集合中的元素,但不包含同时存在于两个集合中的元素。
set18 = {1, 2, 'a'}
set19 = {1, 3, 'b'}

set18.symmetric_difference_update(set19)
print(set18)  # {2, 3, 'a', 'b'}
print(set19)  # {'b', 1, 3}

在这里插入图片描述

  • union: 返回两个集合的并集两个集合的并集
set20 = {1, 2, 'a'}
set21 = {1, 3, 'b'}

print(set20.union(set21))  # {'a', 1, 2, 3, 'b'}

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/696836.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

手撕设计模式——克隆对象之原型模式

1.业务需求 ​ 大家好&#xff0c;我是菠菜啊&#xff0c;前俩天有点忙&#xff0c;今天继续更新了。今天给大家介绍克隆对象——原型模式。老规矩&#xff0c;在介绍这期之前&#xff0c;我们先来看看这样的需求&#xff1a;《西游记》中每次孙悟空拔出一撮猴毛吹一下&#x…

【电赛】STM32-PID直流减速电机小车【寻迹+避障+跟随】【更新ing】

一.需求分析 1.主控&#xff1a;STM32C8T6&#xff08;没什么好说的哈哈&#xff09; 2.电机&#xff1a;JAG25-370电机 【问】为什么要用直流减速电机&#xff1f;&#xff1f; PID控制器需要依靠精确的反馈信号来调整其输出&#xff0c;确保电机按照预定的速度和位置运行…

简单聊一下Oracle,MySQL,postgresql三种锁表的机制,行锁和表锁

MySQL&#xff1a; MySQL使用行级锁定和表级锁定。行级锁定允许多个会话同时写入表&#xff0c;适用于多用户、高并发和OLTP应用。表级锁定只允许一个会话一次更新表&#xff0c;适用于只读、主要读取或单用户应用。 比如mysql开启一个窗口执行 begin; update xc_county_a…

激光点云配准算法——Cofinet / GeoTransforme / MAC

激光点云配准算法——Cofinet / GeoTransformer / MAC GeoTransformer MAC是当前最SOTA的点云匹配算法&#xff0c;在之前我用总结过视觉特征匹配的相关算法 视觉SLAM总结——SuperPoint / SuperGlue 本篇博客对Cofinet、GeoTransformer、MAC三篇论文进行简单总结 1. Cofine…

jquery.datetimepicker无法添加清除按钮的问题

项目场景&#xff1a; 自从决定用现有新技术实现CRM老项目起&#xff0c;就开始了我的折腾之路&#xff0c;最近一直在折腾前端页面&#xff0c;不像后端Java&#xff0c;写的有问题运行会报错&#xff0c;大多数报错一搜就能找到解决方案&#xff0c;前端这个倒好&#xff0c…

【Qt】TreeWidget中Item的UserCheckable注意事项,没有出现多选框

1. 异常 开启 ItemIsUserCheckable以后&#xff0c;界面上没有出现多选框。 QTreeWidgetItem *item new QTreeWidgetItem();item->setText(0, "hello");item->setFlags(Qt::ItemIsUserCheckable | Qt::ItemIsSelectable |Qt::ItemIsEnabled | Qt::ItemIsAuto…

Linux---防火墙

文章目录 目录 文章目录 前言 一.静态防火墙&#xff1a;iptables iptables五链 iptables 四表 iptables控制类型 iptables命令配置 前言 这儿主要介绍Linux系统本身提供的软件防火墙的功能&#xff0c;即数据包过滤机制。 数据包过滤&#xff0c;也就是分析进入主机的网络数…

k8s 1.28 搭建rabbitmq集群

1.环境 1.1 k8s 1.28 1.2 rabbit 3.8 1.3 工作空间default 1.4 注意&#xff0c;内存最好充足一点&#xff0c;因为我就两个节点一个master、一个node&#xff0c;起初我的node是8g&#xff0c;还剩3~4G&#xff0c;集群竟然一直起不来&#xff0c;后来将虚拟机内存扩大&#x…

刷机维修进阶教程-----红米k30 nv损坏故障 修复实例教程步骤解析

小米红米系列机型在米8起始就有了串码校验。不得随意更改参数限制。不同于其他机型,可以任意刷入同芯片的基带qcn来修复基带和串码丢失。米系列刷入同芯片基带qcn会提示nv损坏故障。是因为有串码校验。一般在于格机或者全檫除分区后写新参数出现的故障。 这种解决方法通常有两…

武忠祥17堂课没必要全听,这几个才是精华!

作者&#xff1a;Captain 链接&#xff1a;https://www.zhihu.com/question/381665751/answer/3197724055 来源&#xff1a;知乎 著作权归作者所有。商业转载请联系作者获得授权&#xff0c;非商业转载请注明出处。 17堂课类似于习题课&#xff0c;是专题训练 17堂课省略了…

fs.1.10 ON rockylinux8 docker镜像制作

概述 freeswitch是一款简单好用的VOIP开源软交换平台。 rockylinux docker上编译安装fs1.10版本的流程记录。 环境 docker engine&#xff1a;Version 24.0.6 rockylinux docker&#xff1a;8 freeswitch&#xff1a;v1.10.7 手动模式 rockylinux准备 docker hub拉取r…

IPv4 子网掩码计算器—python代码实现

今天聊一下&#xff0c;我用python和vscode工具实现一个IPv4计算器的一些思路&#xff0c;以及使用Python编写IPv4计算器一些好处&#xff1f; 首先&#xff0c;一、Python语法简洁易读&#xff0c;便于理解和维护&#xff0c;即使对编程不熟悉的用户也能快速了解代码逻辑。其…

基于51单片机的车辆动态称重系统设计

一 动态称重 所谓动态称重是指通过分析和测量车胎运动中的力,来计算该运动车辆的总重量、轴重、轮重和部分重量数据的过程。动态称重系统按经过车辆行驶的速度划分,可分为低速动态称重系统与高速动态称重系统。因为我国高速公路的限速最高是120,所以高速动态称重系统在理论…

AI大模型探索之路-实战篇16:优化决策流程:Agent智能数据分析平台中Planning功能实践

系列篇章&#x1f4a5; AI大模型探索之路-实战篇4&#xff1a;深入DB-GPT数据应用开发框架调研 AI大模型探索之路-实战篇5&#xff1a;探索Open Interpreter开放代码解释器调研 AI大模型探索之路-实战篇6&#xff1a;掌握Function Calling的详细流程 AI大模型探索之路-实战篇7…

【机器学习系列】深入理解集成学习:从Bagging到Boosting

目录 一、集成方法的一般思想 二、集成方法的基本原理 三、构建集成分类器的方法 常见的有装袋&#xff08;Bagging&#xff09;和提升&#xff08;Boosting&#xff09;两种方法 方法1 &#xff1a;装袋&#xff08;Bagging&#xff09; Bagging原理如下图&#xff1a; …

使用SourceTree切换不同的托管平台

背景&#xff1a;sourcetree一开始绑定了gitee&#xff0c;想拉取github的项目时拉取不了 原因&#xff1a;git绑定的账号&#xff08;邮箱&#xff09;、密码不一致 解决办法&#xff1a; 重新设置账号密码 在windows种可找到下面的文件夹&#xff0c;进行删除 C:\Users\US…

第1章Hello world 3/5:Cargo.lock:确保构建稳定可靠:运行第一个程序

讲动人的故事,写懂人的代码 1.6 Cargo.lock:确保构建稳定可靠 “看!”席双嘉一边指着屏幕一边说,“终端窗口提示符的颜色,从绿变黄了。这就意味着代码在上次提交后有点变化。” 赵可菲:“但是我们只是运行了程序,代码应该没动呀。” 席双嘉敲了下git status -uall,这…

设计随笔 ---- ADR4525 篇

ADR4525一颗超低噪声、高精度2.5V基准电压源&#xff1b; Fluke 17B准确度指标&#xff1a; ADR4525指标&#xff1a; Fluke 17B测试结果&#xff1a; 2.5V的基准&#xff0c;输出只有2.477V&#xff0c;其实这么高精度的电压基准用3位半的万用表来测试本身就是一个错误&#…

vscode侧边栏错乱重制

vscode 重制命令面板 View: Reset View Locations

这公司是怎么存活的?真的有存在的必要吗?

原址&#xff1a;OfferNow 大家好&#xff0c;我是白露啊。 昨天看到一个招聘经历的分享&#xff0c;简直让我怀疑人生。 还能有这样的公司&#xff1f; 对方HR说&#xff1a;“*** &#xff0c;学习期间是单休&#xff0c;每天需要加班4-5小时&#xff0c;并且学习期间每天要…