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值的排序

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

dvwa靶场通关(十一)

第十一关&#xff1a;Reflected Cross Site Scripting (XSS) low 这一关没有任何防护&#xff0c;直接输入弹窗 <script>alert(xss)</script> 打开网页源代码&#xff0c; 从源代码中我们可以看到&#xff0c;前面是输出的第一部分Hello&#xff0c;我们输入的脚…

IL汇编实现两数相加输出结果

话说前面没有实现IL汇编2数相加&#xff1b;鼓捣了一下&#xff0c;实现的代码如下&#xff1b; .assembly extern mscorlib {}.assembly Test{.ver 1:0:1:0}.module test.exe.method static void main() cil managed{.maxstack 8.entrypoint.locals init (int32 V_0, int3…

压力测试与测试工具jmeter的介绍

目录 一、性能指标 二、jmeter &#xff08;一&#xff09;JMeter 安装 &#xff08;二&#xff09;JMeter 压测示例 1、添加线程组 2、添加 HTTP 请求 3、添加监听器 4、启动压测&查看分析结果 &#xff08;三&#xff09;JMeter Address Already in use 错误解决 压力测…

微信小程序真机防盗链referer问题处理

公司使用百度云存储一些资源&#xff0c;然后现在要做防盗链&#xff0c;在CDN加入Referer白名单后发现PC是正常的&#xff0c;微信小程序无法正常访问资源了。然后是各种查啊&#xff0c;然后发现是微信小程序不支持Referer的修改&#xff0c;且在小程序开发工具是Referer是固…

ppt压缩文件怎么压缩最小?文件压缩技巧分享

在日常的工作和学习中&#xff0c;难免会遇到PPT太大&#xff0c;需要将其压缩变小的情况&#xff0c;但很多朋友还不知道怎么压缩PPT文件&#xff0c;下面就给大家分享几个简单的方法&#xff0c;分分钟缩小过大的PPT文件。 一、PowerPoint PowerPoint就是微软公司的演示文稿…

【BASH】回顾与知识点梳理(六)

【BASH】回顾与知识点梳理 六 六. 管线命令 (pipe)6.1 撷取命令&#xff1a; cut, grepcutgrep 6.2 排序命令&#xff1a; sort, wc, uniqsortuniqwc 6.3 双向重导向&#xff1a; tee6.4 字符转换命令&#xff1a; tr, col, join, paste, expandtrcoljoinpasteexpand 6.5 分区命…

自定义elementui的主题

通常情况下&#xff0c;我们使用elementui框架的时候默认组件的主题都是白色的&#xff0c;比如&#xff1a; 但是如果想自定义主题&#xff0c;改变主题颜色&#xff0c;以及各种默认颜色&#xff0c;其实也不难&#xff1a; 配置默认主题&#xff0c;选好后点击下载 在vu…

【websocket - Tornado】简易聊天应用

1、背景 项目测试的过程中需要自己搭建一个webscoket站点,确保此类服务接入后台系统后访问不受影响。python的服务框架常用的有Flask、Django、Tornado,每个框架的侧重点不同,导致使用的场景就会有所差异。 Flask轻量级,采用常规的同步编程方式,需要安装其他模块辅助,主…

从0到1开发go-tcp框架【3-读写协程分离、引入消息队列、进入连接管理器、引入连接属性】【基础篇完结】

从0到1开发go-tcp框架【3-读写协程分离、引入消息队列、进入连接管理器、引入连接属性】 1 读写协程分离[v0.7] 添加一个Reader和Writer之间通信的channel添加一个Writer goroutineReader由之前直接发送给客户端改为发送给通信channel启动Reader和Writer一起工作 zinx/znet/co…

英特尔傲腾CAS报错unknown error cache acceleration software could not start cache

英特尔傲腾CAS报错unknown error cache acceleration software could not start cache 文章目录 英特尔傲腾CAS报错unknown error cache acceleration software could not start cache我是怎么遇到这个问题的我是如何解决的实验步骤打Primo Cache蓝屏补丁拔掉原来的系统盘开关机…

【数据结构】常见的排序算法

常见的排序算法 常见的排序算法插入排序之直接插入排序时间复杂度特性总结 插入排序之希尔排序时间复杂度 选择排序之直接选择排序特性总结 选择排序之堆排序时间复杂度特性总结 交换排序之冒泡排序特性总结 交换排序之快速排序hoare版本挖坑法双指针法快速排序的优化1&#xf…

HTML5中Canvas学习笔记:Canvas

目录 一、HTML中Canvas画图strokeStyle 和 fillStyle 的区别是什么&#xff1f; 二、如何设置一幅canvas图中某个颜色透明&#xff1f; 三、H5 canvas中strokeRect参数如果是小数&#xff0c;如何处理&#xff1f; 四、H5 Canvas中如何画圆角矩形框&#xff1f; 一、HTML中…