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.mzph.cn/news/24110.shtml

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

相关文章

LeetCode113. 路径总和 II

113. 路径总和 II 文章目录 [113. 路径总和 II](https://leetcode.cn/problems/path-sum-ii/)一、题目二、题解方法一&#xff1a;递归另一种递归版本方法二&#xff1a;迭代 一、题目 给你二叉树的根节点 root 和一个整数目标和 targetSum &#xff0c;找出所有 从根节点到叶…

java+python企业会议在线办公微信小程序 ia505

一、小程序端功能 该部分内容提供员工注册、员工资料修改、通知公告、部门信息、会议记录等等功能。 二、管理员管理功能 该部分内容包含了首页、个人中心、通知公告管理、员工管理、部门信息管理、职位信息管理、会议记录管理、待办事项管理、工资信息管理、留言板管理、系统管…

C++ 类型兼容规则

类型兼容规则是指在需要基类对象的任何地方&#xff0c;都可以使用公有派生类的对象来替代。 通过公有继承&#xff0c;派生类得到了基类中除构造函数和析构函数之外的所有成员。这样&#xff0c;公有派生类实际就具备了基类的所有功能&#xff0c;凡是基类能解决的问题&#x…

微信支付官方文档怎么看

博主介绍&#xff1a;✌全网粉丝3W&#xff0c;全栈开发工程师&#xff0c;从事多年软件开发&#xff0c;在大厂呆过。持有软件中级、六级等证书。可提供微服务项目搭建与毕业项目实战&#xff0c;博主也曾写过优秀论文&#xff0c;查重率极低&#xff0c;在这方面有丰富的经验…

Cilium系列-14-Cilium NetworkPolicy 简介

系列文章 Cilium 系列文章 前言 今天我们进入 Cilium 安全相关主题, 介绍 Kubernetes 网络策略以及 CiliumNetworkPolicies 额外支持的内容。 网络策略(NetworkPolicy)的类型 默认情况下&#xff0c;Kubernetes 集群中的所有 pod 都可被其他 pod 和网络端点访问。 网络策…

Kafka3.0.0版本——Broker(Zookeeper服务端存储的Kafka相关信息)

目录 一、启动zookeeper集群及kafka集群服务启动1.1、先启动三台zookeeper集群服务&#xff0c;再启动三台kafka集群服务1.2、使用PrettyZoo连接zookeeper客户端工具 二、在zookeeper服务端存储的Kafka相关信息 一、启动zookeeper集群及kafka集群服务启动 1.1、先启动三台zook…

计算机成下一个土木了吗?

前些年抓住了互联网行业的红利期&#xff0c;进入大厂的员工&#xff0c;基本可以实现在一线城市买房扎根。 但反观现在&#xff0c;“被毕业、逃离互联网、躺平算了...”却成了这个行业的主旋律&#xff0c;不少人在谈论润到国企和外企去了&#xff0c;也放低了对工资的预期&…

LIME(可解释性分析方法)

目录 1.什么是LIME 2.思路 3.LIME在不同任务中的范式&#xff08;待补充&#xff09; 1.什么是LIME 简单理解&#xff1a; 对于分类任务&#xff1a;如下图所示&#xff0c;LIME可以列出分类结果&#xff0c;所依据特征对应给比重。 对于图像分类任务&#xff1a;如下图所示&a…

docker 配置 Mysql主从集群

Docker version 20.10.17, build 100c701 MySQL Image version: 8.0.32 Docker container mysql-master is source. mys ql-replica is replication. master source. replica slave.名称叫法不一样而已。 Choose one of the way&#xff0c;与replica同步数据两种情况&…

【Shell】基础语法(一)

文章目录 一、shell的介绍二、执行脚本三、shell的基本语法1. 变量的使用2. 变量的分类 一、shell的介绍 Shell的作用是解释执行用户的命令&#xff0c;用户输入一条命令&#xff0c;Shell就解释执行一条&#xff0c;这种方式称为交互式&#xff08;Interactive&#xff09;&a…

不规则文件转JSON

需求分析&#xff1a; 有时候&#xff0c;我们取出来的数据并不是一个规则的JSON文件&#xff0c;这个时候面对存库还是ES检索都是一个问题&#xff0c;所以我们就需要进行解析&#xff0c;然而用字符串分割是不现实的&#xff0c;我们需要一种快速的方法。 问题解决&#x…

Linux-centos花生壳实现内网穿透

Linux-centos花生壳实现内网穿透 官网教程 1.安装花生壳 下载网址 点击复制就可以复制下载命令了 wget "https://dl.oray.com/hsk/linux/phddns_5.2.0_amd64.rpm" -O phddns_5.2.0_amd64.rpm# 下载完成之后会多一个rpm文件 [rootlocalhost HuaSheng]# ls phddns_…

flask中的应用上下文

flask中的应用上下文 Flask应用上下文主要包含两个对象&#xff1a;current_app和g。这两个对象在处理请求期间都是全局可访问的&#xff0c;但在每个请求结束时都会被重置。 current_app&#xff1a;这是当前激活的Flask应用的实例。在大多数情况下&#xff0c;你可以将其视为…

刷题DAY16

题目一 给定两个字符串str1和str2&#xff0c;再给定三个整数ic、dc和rc&#xff0c;分别代表插入、删除和替换一个字符的代价&#xff0c;返回将str1编辑成str2的最小代价。【举例]str1"abc",str2“adc",ic5,dc3,rc2从“abc“编辑成adc",把b替换成d是代价…

zookeeper --- 高级篇

一、zookeeper 事件监听机制 1.1、watcher概念 zookeeper提供了数据的发布/订阅功能&#xff0c;多个订阅者可同时监听某一特定主题对象&#xff0c;当该主题对象的自身状态发生变化时(例如节点内容改变、节点下的子节点列表改变等)&#xff0c;会实时、主动通知所有订阅者 …

epoll、poll、select的原理和区别

select&#xff0c;poll&#xff0c;epoll都是IO多路复用的机制。I/O多路复用就是通过一种机制&#xff0c;一个进程可以监视多个描述符&#xff0c;一旦某个描述符就绪&#xff08;一般是读就绪或者写就绪&#xff09;&#xff0c;能够通知程序进行相应的读写操作。但select&a…

Markdown学习简记

目录 一、写Markdown的第0步 二、语法须知 标题 粗体强调 斜体 斜体同时粗体 删除线 高亮 代码 代码块 引用块 无序列表 有序列表 链接 表格 图片 分割线 目录生成 内联HTML代码 Typora常用快捷键 Typora的主题样式与检查元素 一、写Markdown的第…

Django Rest_Framework(三)

文章目录 1. 认证Authentication2. 权限Permissions使用提供的权限举例自定义权限 3. 限流Throttling基本使用可选限流类 4. 过滤Filtering5. 排序Ordering6. 分页Pagination可选分页器 7. 异常处理 ExceptionsREST framework定义的异常 8. 自动生成接口文档coreapi安装依赖设置…

Javaweb学习(2)

Javaweb学习 一、Maven1.1 Maven概述1.2 Maven简介1.3、Maven基本使用1.4、IDEA配置Maven1.6、依赖管理&依赖范围 二、MyBatis2.1 MyBatis简介2.2 Mybatis快速入门2.3、解决SQL映射文件的警告提示2.4、Mapper代理开发 三、MyBaits核心配置文件四、 配置文件的增删改查4.1 M…

Flink之RedisSink

在Flink开发中经常会有将数据写入到redis的需求,但是Flink官方并没有对应的扩展包,这个时候需要我们自己编译对应的jar资源,这个时候就用到了bahir,barhir是apahce的开源项目,是专门给spark和flink提供扩展包使用的,bahir官网,这篇文章就介绍下如何自己编译RedisSink扩展包. 下…