[Python] 深入理解列表和元组

在学习的C语言中有数组可以用来存储数据,那么在Python中是否也有这样的工具呢?接下来让可莉来给大家讲解列表和元组这两个强力工具吧~

                                     

                                        专栏:《Python》

                                        blog:Keven ’ s blog

在 Python 中,列表和元组是两种常用的序列数据类型,用于存储和操作一组数据。虽然它们的用

途相似,但它们在一些方面有很大的不同。在本篇博客中,可莉将跟着大家一起深入了解它们的特

点、用法和区别。

列表

在编程中,我们经常需要变量来保存数据,如果要保存的数据数量较少的话我们可以创建变量来进行保存,那如果数据很多呢?这时候就要引入列表的概念了。

创建列表

创建列表有两种方式:

alist = [ ] #第一种
alist = list() #第二种print(type(alist))

如果需要往里面设置初始值, 可以直接写在 [ ] 当中

alist = [1, 2, 3, 4]
print(alist)

与Java和C++不同,在列表中可以存储不同类型的数据

alist = [1, 'hello', True]
print(alist)

访问下标

我们可以用下标运算符[ ] 来访问列表中的任意元素。通常,我们把 [ ] 中填写的数字成为下标或者索引。

alist = [1, 2, 3, 4]
print(alist[2])

下标是从0开始的,也就是说0对应的是列表中第一个元素,1对应的第二个元素,以此类推,如果列表的大小是n个元素,那么最大的下标就是n - 1。

通过下标不仅能访问数据,也能修改数据:

alist = [1, 2, 3, 4]
alist[2] = 100
print(alist)

当访问元素时下标超出有效范围时,程序会抛出异常:

alist = [1, 2, 3, 4]
print(alist[100])

我们可以用len来得到列表的大小:

alist = [1, 2, 3, 4]
print(len(alist))

通过len得到列表大小后在之后的运用中会使操作更加方便。

在Python中一个与C++,Java不同的地方就是它的列表元素可以用负数下标来获取,具体对应元素如下图所示。

我们通过代码运行看下:

alist = [1, 2, 3, 4]
print(alist[3])
print(alist[-1])

运行结果:

                                     

切片操作

通过下标操作是一次取出里面第一个元素.通过切片, 则是一次取出一组连续的元素, 相当于得到一

个子列表。

  • 使用 [ : ] 的方式进行切片操作
alist = [1, 2, 3, 4]
print(alist[1:3])

                           

alist[1:3] 中的 1:3 表示的是 [1, 3) 这样的由下标构成的前闭后开区间.

也就是从下标为 1 的元素开始(2), 到下标为 3 的元素结束(4), 但是不包含下标为 3 的元素.

所以最终结果只有 2, 3 

  • 切片操作中可以省略前后边界(具体规则如下)
alist = [1, 2, 3, 4]
print(alist[1:]) # 省略后边界, 表示获取到列表末尾
print(alist[:-1]) # 省略前边界, 表示从列表开头获取
print(alist[:]) # 省略两个边界, 表示获取到整个列表.

                  

  • 切片操作还可以指定 "步长" , 也就是 "每访问一个元素后, 下标自增几步"
alist = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
print(alist[::1])
print(alist[::2])
print(alist[::3])
print(alist[::5])

  • 切片操作指定的步长还可以是负数, 从后往前进行取元素. 表示 "每访问一个元素之后, 下标自减几步"
alist = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
print(alist[::-1])
print(alist[::-2])
print(alist[::-3])
print(alist[::-5])

  • 如果切片中填写的数字越界了, 不会有负面效果. 只会尽可能的把满足条件的元素都取到

但如果两个界限都超出了范围的话就会取不到元素,但也没有报错:

alist = [1, 2, 3, 4]
print(alist[100:200])

                                     

遍历列表元素

下面将进行讲解如何进行遍历数列元素。

for循环

下面这个方法的for循环只适合对列表中的元素进行只读状态,不能改变列表中的元素:

alist = [1, 2, 3, 4]
for elem in alist:print(elem)

                        

而通过下标的方法来访问可以对列表中的元素进行访问并且修改和操作:

alist = [1, 2, 3, 4]
for i in range(0, len(alist)):print(alist[i])

这个与上面的打印效果效果相同,接下来再举例一个进行修改元素的例子:

alist = [1, 2, 3, 4]
for i in range(0, len(alist)):alist[i] = 0
print(alist)

                        

while循环

alist = [1, 2, 3, 4]
i = 0
while i < len(alist):print(alist[i])i += 1

通过添加 i 的增加来控制循环。

新增元素

append

我们可以用append的方法向列表后面增添一个元素:

alist = [1, 2, 3, 4]
alist.append('hello')
print(alist)

此处的append是搭配列表对象alist来使用的,而不是作为一个独立的函数,是一种搭配对象的函数。

insert

我们可以通过insert来对列表中任意位置进行增添元素:

a  = [1, 2, 3, 4]
a.insert(1, 'hello')
a.insert(100, 'hello')
print(a)

函数的第一个形参位置填写的是要访问的位置的下标,第二个位置是要添加的元素。如果要添加的位置超出了列表的范围,它还是会尽量的进行添加,则添加到了列表的最后位置。

查找元素

用 in 查找

a = [1, 2, 3, 4]
print(1 in a)
print(10 in a)
print(1 not in a)
print(10 not in a)

可以通过in来进行查找,当in加上not时相当于对in进行逻辑取反。当用in找到元素时就会返回True,否则为False,用not in则是逻辑相反。

                                 

用 index 查找

使用 index 方法, 查找元素在列表中的下标. 返回值是一个整数. 如果元素不存在, 则会抛出异常。

alist = [1, 2, 3, 4]
print(alist.index(2))
print(alist.index(10))

删除元素
 

pop

alist = [1, 2, 3, 4]
alist.pop(2)
print(alist)

可以用pop来删除元素,如果只是alist.pop的话删除的是列表的最后一个元素,如果在( )中填写下标的话,那么pop就会通过下标来删除对应下标的元素。

remove

alist = [1, 2, 3, 4]
alist.remove(2)
print(alist)

                    

通过在remove的( )中填写要删除的元素即可达到删除对应元素的效果。

连接列表

使用 + 拼接

此处的 + 结果会生成一个新的列表. 而不会影响到旧列表的内容。

alist = [1, 2, 3, 4]
blist = [5, 6, 7]
print(alist + blist)

     

extend

使用 extend 方法, 相当于把一个列表拼接到另一个列表的后面。a.extend(b) , 是把 b 中的内容拼接到 a 的末尾. 不会修改 b, 但是会修改 a

alist = [1, 2, 3, 4]
blist = [5, 6, 7]
alist.extend(blist)
print(alist)
print(blist)

    

元组

元组和列表相比,基本是一致的。

元组用()表示(或者tuple()):

atuple = ( )
atuple = tuple()

元组与列表最大的区别就是:元组不能修改里面的元素, 列表则可以修改里面的元素

因此, 像读操作,比如访问下标, 切片, 遍历, in, index, + 等, 元组也是一样支持的,但是, 像写操作,

比如修改元素, 新增元素, 删除元素, extend 等, 元组则不能支持。

元组在 Python 中很多时候是默认的集合类型. 例如, 当一个函数返回多个值的时候:

def getPoint():return 10, 20result = getPoint()
print(type(result))

可莉的总结

  • 列表和元组都是日常开发最常用到的类型. 最核心的操作就是根据 [ ] 来按下标操作.
  • 在需要表示一个 "序列" 的场景下, 就可以考虑使用列表和元组.
  • 如果元素不需要改变, 则优先考虑元组.
  • 如果元素需要改变, 则优先考虑列表.

希望大家通过和可莉一起学习这篇博客能可以你更好地理解列表和元组,并选择适当的数据类型来处理你的数据,加油~

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

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

相关文章

今日学习总结

今天在看kmp算法和复习之前学习过的内容&#xff0c;把之前没认真看懂的内容全部又看了一边理解了一遍。 KMP kmp算法基本的作用是查找一个字符串在另一个字符串中出现的位置&#xff08;优化算法&#xff09;。是对暴力算法的优化&#xff0c;暴力算法是在主串中一个一个向后…

Linux操作系统基础(三):虚拟机与Linux系统安装

文章目录 虚拟机与Linux系统安装 一、系统的安装方式 二、虚拟机概念 三、虚拟机的安装 四、Linux系统安装 1、解压人工智能虚拟机 2、找到解压目录中的node1.vmx 3、启动操作系统 虚拟机与Linux系统安装 一、系统的安装方式 Linux操作系统也有两种安装方式&#xf…

【Linux系统学习】3.Linux用户和权限

Linux用户和权限 1.认知root用户 1.1 root用户&#xff08;超级管理员&#xff09; 无论是Windows、MacOS、Linux均采用多用户的管理模式进行权限管理。 在Linux系统中&#xff0c;拥有最大权限的账户名为&#xff1a;root&#xff08;超级管理员&#xff09; 而在前期&#…

代码随想录 Leetcode55. 跳跃游戏

题目&#xff1a; 代码(首刷自解 2024年2月9日&#xff09;&#xff1a; class Solution { public:bool canJump(vector<int>& nums) {int noz 0;for (int i nums.size() - 2; i > 0; --i) {if (nums[i] 0) {noz;continue;} else {if (nums[i] > noz) noz …

Python概率建模算法和图示

要点 Python朴素贝叶斯分类器解释概率学习示例Python概率论&#xff0c;衡量一个或多个变量相互依赖性&#xff0c;从数据中学习概率模型参数&#xff0c;贝叶斯决策论&#xff0c;信息论&#xff0c;线性代数和优化Python线性判别分析分类模型&#xff0c;逻辑回归&#xff0…

基于LightGBM的回归任务案例

在本文中&#xff0c;我们将学习先进的机器学习模型之一&#xff1a;Lightgbm。在对XGB模型进行了越来越多的改进以获得更好的性能之后&#xff0c;XGBoost是一种极限梯度提升机器&#xff0c;但通过lightgbm&#xff0c;我们可以在没有太多计算的情况下实现类似或更好的结果&a…

【QT+QGIS跨平台编译】之三十:【NetCDF+Qt跨平台编译】(一套代码、一套框架,跨平台编译)

文章目录 一、NetCDF介绍二、文件下载三、文件分析四、pro文件4.1 netcdf34.2 netcdf44.3 netcdf五、编译实践一、NetCDF介绍 NetCDF(Network Common Data Form)是一种用于存储和处理科学数据的文件格式和库。它提供了一种自描述、可移植和可扩展的方式来组织多维数据,并支…

动态更改 Spring 定时任务 Cron 表达式的优雅方案

1.接受说明 在 SpringBoot 项目中,我们可以通过@EnableScheduling注解开启调度任务支持,并通@Scheduled注解快速地建立一系列定时任务。 最常用的应该是第一种方式,基于Cron表达式的执行模式,因其相对来说更加灵活。 @Scheduled支持下面三种配置执行时间的方式: 1.cron(e…

力扣热题100_双指针_283_移动零

文章目录 题目链接解题思路解题代码 题目链接 283. 移动零 给定一个数组 nums&#xff0c;编写一个函数将所有 0 移动到数组的末尾&#xff0c;同时保持非零元素的相对顺序。 请注意 &#xff0c;必须在不复制数组的情况下原地对数组进行操作。 示例 1: 输入: nums [0,1,…

vscode debug无法直接查看eigen变量的问题(解决方法)

主要是给gdb添加一个Eigen相关的printer即可, 网上其他教程都搞太复杂了, 我整理成了一个仓库, 把仓库克隆下来直接运行 ./setup.sh脚本即可配置好 git clone gitgithub.com:fandesfyf/EigenGdb.git cd EigenGdb ./setup.sh 然后在vscode中重新debug即可。 效果 …

MySQL存储引擎、事务、锁、日志

存储引擎 概述 数据库存储引擎是数据库底层软件组织&#xff0c;数据库管理系统(DBMS)使用数据引擎进行创建、查询、更新和删除数据。不同的存储引擎提供不同的存储机制、索引技巧、锁定水平等功能。现在许多不同的数据库管理系统都支持多种不同的数据引擎。MySQL的核心就是存…

linux驱动工作原理

linux或者windows驱动是如何对上和对下工作的&#xff0c;请用中文回答 在Linux系统中&#xff0c;设备驱动程序通过在/dev目录下创建文件系统条目与硬件通信。应用程序通过打开这些文件来获取描述符&#xff0c;以此来与设备交互。驱动程序内部使用主次设备号来标识设备。而在…

使用Arcgis裁剪

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、掩膜提取二、随意裁剪三、裁剪 前言 因为从网站下载的是全球气候数据&#xff0c;而我们需要截取成中国部分&#xff0c;需要用到Arcgis的裁剪工具 一、掩…

对比 elasticsearch 和 mysql

https://www.cnblogs.com/darcy-yuan/category/2257608.html 最近阅读了elasticsearch的官方文档&#xff0c;学习了它的很多特性&#xff0c;发现elasticsearch和mysql有很多地方类似&#xff0c;也有很多地方不同。这里做一个对比&#xff0c;帮助大家加深对elasticsearch…

鸿蒙(HarmonyOS)项目方舟框架(ArkUI)之Slider组件

鸿蒙&#xff08;HarmonyOS&#xff09;项目方舟框架&#xff08;ArkUI&#xff09;之Slider组件 一、操作环境 操作系统: Windows 10 专业版、IDE:DevEco Studio 3.1、SDK:HarmonyOS 3.1 二、Slider组件 滑动条组件&#xff0c;通常用于快速调节设置值&#xff0c;如音量调…

响应式编程详解(持续更新)

响应式编程 1.多维度看全景1.1响应式编程(Reactive Programming )1.2函数式编程&#xff08;Functional Programming, 简称FP&#xff09;1.3技术演进1.4Rx是什么1.5[响应式宣言](https://www.reactivemanifesto.org/zh-CN) 2.钻进去看本质2.1名称解释(rajava)2.2观察者模式2.3…

HLS 三角函数报错:undefined reference to ‘cordic_apfixed::circ_table_arctan_128‘

最近在通过HLS实现一些算法&#xff0c;其中用到了hls::cos函数&#xff0c;写完代码编译报错&#xff1a; ../Vitis_HLS/hls_cordic_apfixed.h:229: undefined reference to cordic_apfixed::circ_table_arctan_128 build/xf_computePhaseMap_accel.o: In function void cord…

注解(Java用于工具处理的标注)

一. 使用注解 1. 含义 注解是放在类&#xff0c;方法&#xff0c;字段&#xff0c;参数前的一种特殊“注释”&#xff0c;是一种用作标注的“元数据”。 2. 三类注解 1&#xff09;由编译器使用的注解&#xff0c;不会编译进.class文件&#xff0c;编译后扔掉&#xff1b;如&…

c实现链表

目录 c实现链表 链表的结构定义&#xff1a; 链表的结构操作&#xff1a; 1、初始化链表 2、销毁链表 3、插入结点 4、输出链表数据 5、查找链表数据 扩展 代码实现 c实现链表 链表的结构定义&#xff1a; /*** 链表结构定义 ***/ typedef struct Node {int data; //…

TCP和UDP相关问题(重点)——6.TCP是如何保证传输的可靠性的?

基于数据块传输&#xff1a;应用数据被分割为合适的数据块发送&#xff0c;并且标记序列号&#xff0c;有了序列号就能将接收到的数据根据序列号进行排序。 校验和&#xff1a;TCP将保持首部和数据的校验和&#xff0c;会检测数据在传输过程中的任何变化&#xff0c;如果校验和…