python数据容器

目录

数据容器

反向索引

list列表

语法

案例 

列表的特点

列表的下表索引

list的常用操作

list列表的遍历

while循环遍历

for循环遍历

tuple元组

前言

元组定义

元组特点

获取元组元素 

元组的相关操作

元组的遍历

while循环遍历

for循环遍历

字符串

前言

获取字符串字符 

字符串的常用操作

字符串的特点

数据容器的切片操作

序列

切片语法 

set集合

集合语法

集合特点

集合的常用操作

集合的遍历

字典

字典定义

字典的特点

通过key获取value

字典的常用操作

遍历字典

数据容器总结

数据容器的通用操作

数据容器通用方法

比较大小

通用容器转换

容器的通用排序功能

数据容器

含义:一种可以容纳多份数据的数据类型,容纳每一份数据称之为一个元素,可以是任意类型的数据,如字符串、数字、布尔等

注意:数据容器根据特点(是否支持重复元素、是否可以修改元素、是否有序等)的不同,可以分为5类,分别是列表(list)、元组(tuple)、字符串(str)、集合(set)、字典(dict)等

反向索引

理解:从后向前的索引,也就是从-1开始,依次递减(-1,-2,-3,……)

#定义列表
my_list=["hello",666,True,888]
print(f"列表第一个元素{my_list[0]},列表最后一个元素{my_list[-1]}")
#列表第一个元素hello,列表最后一个元素888

注意:数据容器中支持下标访问的容器都支持反向索引。

list列表

语法

#定义列表
变量名称=[元素1,元素2,元素3,……]

#定义空列表
变量名称=[]
变量名称=list()

案例 

#定义列表
my_list=["hello",666,True,[1,"app"]]
print(f"列表内容为:{my_list},列表类型为:{type(my_list)}")
#列表内容为:['hello', 666, True, [1, 'app']],列表类型为:<class 'list'>

列表的特点

  • 整个列表用[]括起来,列表中的每个元素用逗号隔开
  • 列表可以一次存储多个数据,且可以为不同数据类型,支持嵌套所有容器(上限为2**63-1)
  • 数据是有序存储的(有下标序号)
  • 允许重复数据存在
  • 数据可以修改(增加或删除元素等)
  • 支持for和while循环遍历

列表的下表索引

前言:我们可以使用列表的下标索引去取出特定位置的数据

理解:在列表中可以存储多个元素,元素是有顺序的,按照顺序从左到右第一个元素他有一个下标索引叫做0,第二个元素索引为1依次类推(从左到右逐步加一)

接收下标索引语法:接受变量=列表名[索引]

注意:使用下标索引时,一定不要超出索引的范围,不然会报错 

list的常用操作

查询某元素下标:接受变量=列表.index(元素)

注意:查找指定元素在列表的下标,若找不到,就会报ValueError错误

修改列表指定下标的值:列表[下标]=新值

在指定下标插入指定元素:列表.insert(下标,元素)

追加指定元素在列表尾部:列表.append(元素)

追加一批元素在列表尾部:列表.extend(其他数据容器)

注意:将数据容器的内容依次取出,追加到列表(若是字典只追加key)

删除列表指定下标元素:del 列表[下标]

删除列表指定下标元素并返回删除元素:变量=列表.pop(下标)

删除列表中指定元素:列表.remove(具体元素)

注意:先拿到具体元素,从列表中由前到后搜索,删除匹配的第一个

清空整个列表:列表.clear()

统计某元素在列表内的数量:接受变量=列表.count(具体元素)

统计列表中全部元素数量:接受变量=len(列表)

list列表的遍历

前言:既然数据容器可以存储多个元素,那么就会有需求从容器内依次取出元素进行操作,将容器内的元素依次取出进行处理的行为,称之为遍历

while循环遍历

index=0
while index<len(列表):
    print(f"列表的第{index+1}个元素为:{列表[index]}")
    index+=1

for循环遍历

index=1
for i in 列表:
    print(f"列表的第{index}个元素为:{i}")
    index+=1

tuple元组

前言

  • 列表是可以修改的,若想要传递的信息不被篡改,列表就不合适了
  • 元组同列表一样,都是可以封装多个、不同类型的元素在内,但是元组一旦定义完成,就不可更改(但是元组内的list内容可修改)

元组定义

#定义元组变量
(元素1,元素2,……,元素n)

#定义空元组
变量名=()
变量名=tuple()

注意:

  • 元组定义单个元素,那么一定要在后面写个逗号("元素",)
  • 元组也支持反向索引

元组特点

  • 整个元组用()括起来,元组中的每个元素用逗号隔开
  • 元组可以一次存储多个数据,且可以为不同数据类型,支持嵌套所有容器
  • 数据是有序储存的(有下标索引)
  • 允许数据重复存在
  • 元素不可修改(但是列表作为元素,列表里的内容可以修改)
  • 支持for循环和while循环

获取元组元素 

获取元组元素:接受变量=元组名[下标]

元组的相关操作

查找某个元素的下标:接受变量=元组.index(具体元素)

统计元素在元组中出现的次数:接受变量=元组名.count(元素名)

统计元组元素数量:接受变量=len(元组名)

元组的遍历

while循环遍历

index=0
while index<len(元组):
    print(f"元组的第{index+1}个元素为:{元组[index]}")
    index+=1

for循环遍历

index=1
for i in 元组:
    print(f"元组的第{index}个元素为:{i}")
    index+=1

字符串

前言

  • 尽管字符串看起来并不像列表、元组那样,一看就是存放许多数据类型的容器,但不可否认,字符串同样也是数据容器中的一员
  • 字符串是字符的容器,一个字符串可以存放任意数量的字符
  • 字符串和其他容器一样也可以通过下标进行访问(从前到后下标从0开始、从后向前下标从-1开始)
  • 同元组一样,字符串是不可修改的数据容器;若必须要做,我们只能得到一个新字符串

获取字符串字符 

获取字符串字符:接收变量=字符串[下标]

字符串的常用操作

查找特定字符串的下标索引值:接受变量=字符串.index(字符串)

str="i love you"
n=str.index("love")
print(f"love在字符串的下标索引为:{n}")#2

将字符串内的字符串1全部替换为字符串2:字符串.replace(字符串1,字符串2)

注意:这里并不是修改字符串本身,而是得到一个新的字符串

字符串分割:列表对象=字符串.split(分隔符字符串)

功能:按照指定的分隔符,将字符串划分为多个字符串,并存取列表对象中(这里字符串本身不变,而是得到一个列表对象)

去除字符串前后空格以及回车符:接收变量=字符串.strip()(字符串本身不变)

去除前后指定的字符串:接受变量=字符串.strip(指定的字符串)(字符串本身不变)

str="12i love you21"
str_1=str.strip("12")
print(f"去除12后字符串的内容为:{str_1}")
#去除12后字符串的内容为:i love you

注意:这里的指定字符串指将这个指定的字符串分为子串后,再看前后固定长度的字符串是否都含有该字串,有则去掉

统计字符串中某个字符串出现的次数:接受变量=字符串.count(子串)

统计字符串的总长度:接受变量=len(字符串)

字符串的特点

  • 字符串作为数据容器只能存储字符串
  • 字符串长度任意(取决于内存大小)
  • 支持下标索引
  • 允许重复字符串存在
  • 字符串内容不可修改(可以创建一个新的字符串)
  • 支持for,while循环

数据容器的切片操作

序列

序列:序列是指内容连续、有序、可使用下标索引的一类数据容器

注意:

  • 列表、元组、字符串都可以称为序列
  • 序列支持切片操作(从一个序列中取出一个子序列)
  • 切片操作并不会影响到序列本身,而是得到一个新的序列

切片语法 

切片语法:新序列=序列[起始下标:结束下标:步长]

理解:表示从序列中,指定位置开始,依次取出元素,直到指定位置结束,得到一个新序列

具体解释

  • 起始下标:表示从何处开始,可以留空,留空视作从头开始
  • 结束下标:表示何时结束,可以留空,留空表示截取到结尾
  • 步长:表示依次取元素的间隔,也可以为负数表示倒着取(默认为1)
my_list=[0,1,2,3,4,5,6]
new_list=my_list[1:5:1]
print(f"切片得到的新序列为:{new_list}")
#切片得到的新序列为:[1, 2, 3, 4]
f_list=my_list[5:1:-1]
print(f"切片得到的新序列为:{f_list}")
#切片得到的新序列为:[5, 4, 3, 2]

set集合

前言:若场景需要对内容做去重处理,那么列表,元组,字符串就不方便了。而集合最主要的特点就是不支持元素的重复(自带去重功能,并且内容无序)

集合语法

#定义集合变量
变量名称={元素1,元素2,……,元素n}
#定义空集合
变量名称=set()

集合特点

  • 整个集合用{}括起来,集合中的每个元素用逗号隔开
  • 集合可以容纳多个不同类型的数据,集合不支持嵌套
  • 数据是无序的,不支持下标索引
  • 不允许重复数据存在
  • 可以修改元素内容
  • 仅支持for循环遍历

集合的常用操作

添加新元素:集合.add(元素)

移除元素:集合.remove(元素)

从集合中随机取出一个元素:接受变量=集合.pop()

清空集合:集合.clear()

取两个集合的差集:新集合=集合1.difference(集合2)

注意:取出集合1有而集合2没有的,得到一个新集合,集合1和集合2本身没有任何改变 

消除两个集合的差集:集合1.difference_update(集合2)

注意:对比集合1和集合2,在集合1内,删除和集合2相同的元素,结果集合1被修改,集合2不变

两个集合合并为1个:新集合=集合1.union(集合2)

注意:将集合1和集合2组合成新集合,结果得到新集合,集合1和集合2不变

统计集合元素数量:变量=len(集合)

集合的遍历

注意:集合不支持下标索引,所以不支持while循环

my_set={1,2,3,4,5}
for i in my_set:
    print(f"集合的元素为:{i}")

字典

前言:通过字典,我们可以实现从key取出value的操作

字典定义

#定义字典变量
变量名={key:value,……,key:value}
#定义空字典
变量名={}
变量名=dict()

注意:

  • 根据字典我们可以实现从key取出value的操作
  • 字典的key不允许重复,若有重复的key,则后面的key会把前面的键值对会把前面的键值对覆盖
  • 字典同集合一样,不可以使用下标索引,但是字典可以通过key值来取得对应的value
  • 字典的value支持嵌套,key不可嵌套
  • 字典若被其他容器嵌套,那么字典只会将key作为其他容器的元素

字典的特点

  • 字典的定义,同样使用{},不过存储的元素是一个个的键值对,每个键值对用逗号隔开,一个键值对一起称为一个元素
  • 可以容纳多个不同类型的数据
  • 每一份数据都是由key和value键值对组成
  • 可以通过key获取到value,数据是无序的,key不可重复
  • 不支持下标索引
  • 可以修改或增加元素
  • 支持for循环不支持while循环

通过key获取value

语法:变量=字典[key]

字典的常用操作

新增/更新元素:字典[key]=value

删除并取出元素:变量=字典.pop(key)

清空字典:字典.clear()

获取全部key:列表对象=字典.keys()

统计字典的元素数量:变量=len(字典) 

遍历字典

前言:因为字典没有下标,所以仅支持for循环遍历

#方式1
for key in 字典.keys():
    print(f"字典的key是:{key}")
    print(f"字典的value是:{字典[key]}")

#方式2
for key in 字典:
    print(f"字典的key是:{key}")
    print(f"字典的value是:{字典[key]}")

数据容器总结

数据容器的通用操作

前言:数据容器尽管各自有各自的特点,但是他们也有通用的一些操作

  • 遍历上5类数据容器都支持for循环遍历,列表、元组、字符串支持while循环,集合、字典不支持(没有下标索引)
  • 数据容器可以通用非常多的功能方法,如len()

数据容器通用方法

比较大小

查找容器最大元素:变量=max(容器)

查找容器最小元素:变量=min(容器)

注意:

  • 字符串比较大小是根据字符串的ASCII码值比较
  • 字典比较大小比较的是key值的大小

通用容器转换

将给定容器转为列表:变量=list(容器)

将给定容器转为字符串:变量=str(容器)

将给定容器转为元组:变量=tuple(容器)

将给定容器转为集合:变量=set(容器)

注意:字典可以转换为别的容器(转换成字符串,那么value就会保留,转换成其他的value就会丢失),但别的容器不可以转换为字典。

容器的通用排序功能

将给定容器进行排序:列表对象=sorted(容器,[reverse=true])

注意:

  • 若想容器的排序进行反转,那么就将reverse的参数改为true
  • 排序后的结果统统变为列表对象
  • 字典的排序是对key值的排序

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

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

相关文章

MySQL事务篇:ACID原则、事务隔离级别及事务机制原理剖析

引言 众所周知&#xff0c;MySQL数据库的核心功能就是存储数据&#xff0c;通常是整个业务系统中最重要的一层&#xff0c;可谓是整个系统的“大本营”&#xff0c;因此只要MySQL存在些许隐患问题&#xff0c;对于整个系统而言都是致命的。那此刻不妨思考一个问题&#xff1a; …

HTML5+CSS3小实例:带标题的3D多米诺人物卡片

实例:带标题的3D多米诺人物卡片 技术栈:HTML+CSS 效果: 源码: 【html】 <!DOCTYPE html> <html><head><meta http-equiv="content-type" content="text/html; charset=utf-8"><meta name="viewport" content…

Unity 引擎做残影效果——2、屏幕后处理方式

Unity实现残影效果 大家好&#xff0c;我是阿赵。 这里继续介绍Unity里面做残影的方法。之前介绍了BakeMesh的方法做残影&#xff0c;这一期介绍的是用屏幕后处理的方法做残影。 一、原理 之前的BakeMesh方法&#xff0c;是真的生成了很多个网格模型在场景里面。如果用后处理做…

前端如何打开钉钉(如何唤起注册表中路径与软件路径不关联的软件)

在前端唤起本地应用时&#xff0c;我查询了资料&#xff0c;在注册表中找到腾讯视频会议的注册表情况&#xff0c;如下&#xff1a; 在前端代码中加入 window.location.href"wemeet:"; 就可以直接唤起腾讯视频会议&#xff0c;但是我无法唤起钉钉 之所以会这样&…

使用手机相机检测电脑屏幕刷新率Hz

使用手机相机检测电脑屏幕刷新率Hz 1、电脑打开https://www.testufo.com/frameskipping 2、相机专业模式&#xff1a;快门1/10、ISO自动&#xff0c;拍摄一张照片。120Hz至少要有12个亮块&#xff0c;50Hz至少有6个亮块。 更改刷新速率 1、选择 “开始>设置>系统>显示…

Nodejs 第八章(npm搭建私服)

构建npm私服 构建私服有什么收益吗&#xff1f; 可以离线使用&#xff0c;你可以将npm私服部署到内网集群&#xff0c;这样离线也可以访问私有的包。提高包的安全性&#xff0c;使用私有的npm仓库可以更好的管理你的包&#xff0c;避免在使用公共的npm包的时候出现漏洞。提高…

性能测试/负载测试/压力测试之间的区别

做测试一年多来&#xff0c;虽然平时的工作都能很好的完成&#xff0c;但最近突然发现自己在关于测试的整体知识体系上面的了解很是欠缺&#xff0c;所以&#xff0c;在工作之余也做了一些测试方面的知识的补充。不足之处&#xff0c;还请大家多多交流&#xff0c;互相学习。 …

网络安全(黑客)工具篇

大家好。这篇文章给大家盘点那些年&#xff0c;我们一起玩过的网络安全工具。 一、反恶意代码软件 1.Malwarebytes 这是一个检测和删除恶意的软件&#xff0c;包括蠕虫&#xff0c;木马&#xff0c;后门&#xff0c;流氓&#xff0c;拨号器&#xff0c;间谍软件等等。快如闪…

【JAVASE】多态

⭐ 作者&#xff1a;小胡_不糊涂 &#x1f331; 作者主页&#xff1a;小胡_不糊涂的个人主页 &#x1f4c0; 收录专栏&#xff1a;浅谈Java &#x1f496; 持续更文&#xff0c;关注博主少走弯路&#xff0c;谢谢大家支持 &#x1f496; 多态 1. 概念2. 实现条件3. 重写4. 向上…

ORALCE RAC总结

一&#xff1a;ORACLE RAC集群安装 ASM磁盘管理 二&#xff1a;ORACLE RAC集群报错排查总结 三&#xff1a;ORACLE RAC集群报错排查总结 3.1 ORA-29760: instance_number parameter not specified RAC1节点&#xff0c;RAC2节点 解决 export ORACLE_SIDa81&#xff08;…

重新理解 RocketMQ Commit Log 存储协议

最近突然感觉&#xff1a;很多软件、硬件在设计上是有 root reason 的&#xff0c;不是 by desgin 如此&#xff0c;而是解决了那时、那个场景的那个需求。一旦了解后&#xff0c;就会感觉在和设计者对话&#xff0c;了解他们的思路&#xff0c;学习他们的方法&#xff0c;思维…

基于FPGA的超声波测距——UART串口输出

文章目录 前言一、超声波模块介绍1、产品特点2、超声波模块的时序图 二、系统设计1、系统模块框图2、RTL视图 三、源码1、div_clk_us(1us的分频)2、产生驱动超声波的信号3、串口发送模块4、HC_SR04_uart(顶层文件) 四、效果五、总结六、参考资料 前言 环境&#xff1a; 1、Quar…

阿里云安全组设置

简介​ 云主机安全组必须打开如下端口&#xff1a; ssh&#xff1a;22http&#xff1a;80https&#xff1a;443ftp&#xff1a;21、20000&#xff5e;30000 阿里云安全组端口开放教程​ 腾讯云安全组端口开放教程​ 华为云安全组端口开放教程​

ES6新增的语法

ES6实际上是一个泛指&#xff0c;泛指 ES2015 及后续的版本 1&#xff0c;let用于声明变量的关键字 let 声明的变量只在所处于的代码块内有效 if (true) { let a 10 } console.log(a) // a is not defined 2, let 不存在变量提升 console.log(a) // a is not deined let a 1…

Vue + ElementUI 实现可编辑表格及校验

效果 完整代码见文末 实现思路 使用两个表单分别用于实现修改和新增处理。 通过一个editIndex变量判断是否是编辑状态来决定是否展示输入框&#xff0c;当点击指定行的修改后进行设置即可&#xff1a; <el-table-columnv-for"(column, index) in columns":key&qu…

华为QinQ技术的基本qinq和灵活qinq 2种配置案例

基本qinq配置&#xff1a; 运营商pe设备在收到同一个公司的ce发来的的包&#xff0c;统一打上同样的vlan &#xff0c;如上图&#xff0c;同一个家公司两边统一打上vlan 2&#xff0c;等于在原内网vlan 10或20过来的包再统一打上vlan 2的标签&#xff0c;这样传输就不会和其它…

基于text2vec和faiss开发实现文档查询系统初体验

最近接触到了一些文本向量化的预训练模型&#xff0c;感觉相比较自己去基于gensim去训练词向量来说&#xff0c;使用预训练模型可能是更高效的方式了&#xff0c;正好有一个想法一直在想能够以什么样的形式间接的实现问答&#xff0c;说白了这里的问答跟我们理解的chatGPT类型的…

Spark 3.1.1 遇到的 from_json regexp_replace组合表达式慢问题的解决

背景 目前公司在从spark 2.4.x升级到3.1.1的时候&#xff0c;遇到了一类SQL极慢的情况&#xff0c;该SQL的如下(只列举了关键的)&#xff1a; select device_personas.* from(selectdevice_id, ads_id, from_json(regexp_replace(device_personas, (?<(\\{|,))"devic…

【数据结构】——线性表的相关习题

目录 题型一&#xff08;线性表的存储结构&#xff09;题型二&#xff08;链表的判空&#xff09;题型三&#xff08;单链表的建立&#xff09;题型四&#xff08;顺序表、单链表的插入删除操作&#xff09;题型五&#xff08;双链表的插入删除操作&#xff09;题型六&#xff…

【ARM Coresight 系列文章 2.5 - Coresight 寄存器:PIDR0-PIDR7,CIDR0-CIDR3 介绍】

文章目录 1.1 JEDEC 与 JEP1061.2 PIDR0-PIDR7(peripheral identification registers)1.2 CIDR0-CIDR3(Component Identification Registers) 1.1 JEDEC 与 JEP106 JEDEC和JEP106都是来自美国电子工业联合会&#xff08;JEDEC&#xff0c;Joint Electron Device Engineering C…