【Python】列表和元组

文章目录

  • 概念
  • 创建列表
  • 访问下标
    • 通过下标来修改列表元素
    • 获取列表长度
    • 下标可以写成负数
  • 切片操作
    • 省略后边界
    • 省略前边界
    • 省略前后边界
    • 带有步长的切片
  • 遍历列表元素
    • 使用 for 循环
    • 使用 for 循环访问下标的方式
    • 使用 while 循环
  • 新增元素
    • 在末尾新增
    • 在任意位置新增
  • 查找元素
    • 判定元素是否存在
    • 判定元素的位置
  • 删除元素
    • 删除列表末尾元素
    • 删除任意位置元素
    • 按照值进行删除
  • 列表拼接
    • 使用“`+`”拼接
    • 使用 `extend` 进行拼接
    • 使用“`+=`”拼接
  • 关于元组
    • 创建元组
    • 创建元组时指定初始值
    • 元组中的元素可以使任意类型
    • 通过下标进行访问
    • 切片
    • 遍历元组
    • 查找元素
    • 拼接元组
    • 为什么要有元组

概念

变量就是内存空间,用来表示/存储数据
如果表示的数据少,直接定义几个变量就行了

num1
num2
num3

但有时候要表示的数据比较多

Python 中,列表和元组就是一种可以用一个变量来表示很多数据的机制(类似其他语言中的数组

列表和元组,大部分功能都是差不多的,但是有一个功能有非常明显的区别:

  • 列表是可变的,创建好了之后,随时可以改
  • 元组是不可变的,创建好了之后改不了,若想改,只能丢弃旧的,再创建一个新的

列表就是买散装辣条,装好了袋子之后,随时可以把袋子打开,再往里多加辣条或者拿出去一些辣条
元组就是买包装辣条,厂家生产好了辣条之后,一包就是固定的这么多,不能变动了
image.png

创建列表

  1. 直接使用字面值来创建
a = [1, 2, 3, 4]
print(type(a))
print(a)"""
运行结果
<class 'list'>
[1, 2, 3, 4]
"""
  • []就代表一个空的列表
  • 可以在 [] 中指定列表的初始值,
  1. 使用 list() 来创建
b = list()
print(type(b))"""
运行结果
<class 'list'>
"""

C++/Java 中要求一个数组里只能存放相同的变量,但在 Python 中没有类型要求

a = [1, 'hello', True, [1, 2, 3]]  
print(a)"""
运行结果
[1, 'hello', True, [1, 2, 3]]
"""

访问下标

通过下标访问的方式,来获取列表中的元素
[] 放到一个列表变量的后面,同时 [] 中写上一个整数,此时他就是下标访问运算符。[] 中间写的这个证书,就称为“下标”或者“索引

a = [1, 2, 3, 4]
print(a[2])"""
运行结果
3
"""
  • Python 中的下标,是从 0 开始计数的

通过下标来修改列表元素

a = [1, 2, 3, 4]
a[2] = 100
print(a)"""
运行结果
[1, 2, 100, 4]
"""
  • 这是列表的功能,如果是元组的话,就只能读,不能改

由于下标是从 0 开始计算的,那么对于列表来说,下标的有效范围是 0~长度-1。当我们的下标超出有效范围的时候,尝试访问就会报错 `


获取列表长度

a = [1, 2, 3, 4]
print(len(a))"""
运行结果
4
"""
  • len 可以穿字符串、列表、元组、字典、自定义得嘞…(动态类型)

下标可以写成负数

a = [1, 2, 3, 4]
print(a[lem(a)-1])
print(a[-1])"""
运行结果
3
3
"""
  • -1 就等价与 len(a) - 1

切片操作

切片操作是一个比较高效的操作,进行切片的时候,只是取出原有列表中的一个部分,并不涉及到“数据的拷贝”。假设有一个很大的列表进行切片,切片的范围也很大,即使如此,切片操作仍然非常高效

切片操作中,[] 中有两个数字,表示了一段区间

a = [1, 2, 3, 4]
print(a[1:3])"""
运行结果
[2, 3]
"""
  • 1 表示开始区间的下标;3 表示结束区间的下标
  • 包含 1,不包含 3[1, 3)

省略后边界

a = [1, 2, 3, 4]
print(a[1:])"""
运行结果
[2, 3, 4]
"""
  • a[1] 开始,一直读取到整个列表结束

省略前边界

a = [1, 2, 3, 4]
print(a[:2])"""
运行结果
[1, 2]
"""
  • 从列表的 a[0] 开始读,一直读到结束的后边界

省略前后边界

a = [1, 2, 3, 4]
print(a[:])"""
运行结果
[1, 2, 3, 4]
"""
  • 省略前后边界就是打印整个列表

带有步长的切片

切片操作,还可以指定“步长”,range

a = [1, 2, 3, 4 ,5 , 6, 7 ,8]
print(a[::1])
print(a[::2])"""
运行结果
[1, 2, 3, 4 ,5 , 6, 7 ,8]
[1, 3, 5, 7]
"""
  • 多加一个 :,再多加一个数字,这个数字就是步长
    • 这里表示:每隔两个元素,取一个列表元素
  • 步长也可以设置为负数,当步长为负数时,意思是从后往前来取元素

遍历列表元素

遍历” 指的是把元素一个一个的取出来,再分别进行处理

使用 for 循环

a = [1, 2, 3, 4, 5]  
for elem in a:  print(elem)
  • 在这个遍历过程中,循环里面的逻辑不一定是打印,还可以是别的
  • elem 代表列表里的每个元素
  • for in 后面的这个东西,要求是一个可迭代对象
    • 列表就是一个可迭代对象

使用 for 循环访问下标的方式

a = [1, 2, 3, 4, 5]
for i range(0, len(a)):print(a[i])
  • 相比于上面的方式,这里不仅可以打印,还可以进行修改

使用 while 循环

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

新增元素

在末尾新增

使用 append 往列表末尾新增一个元素

a = [1, 2, 3, 4, 5]  
a.append(77)  
a.append('hello')  
print(a)"""
运行结果
[1, 2, 3, 4, 5, 77, 'hello']
"""
  • 此处的 append 是搭配列表对象 a 一起使用的,而不是作为一个独立的函数
    • typeprintinputlen… 都是独立的函数
  • 这种要搭配对象来使用的函数function)也叫做方法method
    • 在 Python 中,对象就可以视为“变量

在任意位置新增

可以使用 insert 方法,让列表的任意位置来新增元素

a = [1, 2, 3, 4, 5]
a.insert(1, 'hello')
print(a)"""
运行结果
[1, 'hello', 2, 3, 4, 5]
"""
  • a[1] 的位置新增 ’ hello ’ 字符串
  • 如果输入的 index 超过列表的长度,那就直接放在末尾

查找元素

判定元素是否存在

a = [1, 2, 3, 4]
print(1 in a)
print(10 in a)
print(1 not in a)
print(10 not in a)"""
运行结果
True
False
False
True
"""
  • 使用 in 来判定某个元素是否在列表中存在
  • 使用 not in 来判断某个元素在列表中是否不存在

判定元素的位置

a = [1, 2, 3, 4]
print(a.index(2))"""
运行结果
1
"""
  • 使用 index 方法,来判定当前元素在列表中的位置,得到一个下标
  • 找不到的时候就会直接报出异常

删除元素

删除列表末尾元素

a = [1, 2, 3, 4]  
a.pop()  
print(a)"""
运行结果
[1, 2, 3]
"""
  • 使用 pop 方法,删除列表中最末尾的元素

删除任意位置元素

a = [1, 2, 3, 4]  
a.pop(1)  
print(a)"""
运行结果
[1, 3, 4]
"""
  • 使用 pop 方法删除任意位置元素,pop 参数可以传一个下标过去

按照值进行删除

不需要知道下标是什么,只需要知道要删除的值是什么就可以了

a = ['aa', 'bb', 'cc', 'dd']  
a.remove('cc')  
print(a)"""
运行结果
['aa', 'bb', 'dd']
"""

列表拼接

使用“+”拼接

使用 + 能够把两个列表拼接在一起

a = [1, 2, 3, 4]  
b = [5, 6, 7, 8]  
c = a + b  
d = b + a
print(c) 	
print(d)"""
运行结果
[1, 2, 3, 4, 5, 6, 7, 8]
[5, 6, 7, 8, 1, 2, 3, 4]
"""
  • 使用 + 拼接列表的时候,只是针对当前列表的内容生成了一个更大的新的列表
  • 原有列表的内容是不变的

使用 extend 进行拼接

a = [1, 2, 3, 4]  
b = [5, 6, 7, 8]  
c = a.extend(b)  
print(a)  
print(b)  
print(c)
"""
运行结果
[1, 2, 3, 4, 5, 6, 7, 8]
[5, 6, 7, 8]
None
"""
  • 这个拼接是把最后一个列表的内容拼接到前一个列表里面
  • None 是一个特殊的变量值,表示什么都没有
    • extend 方法,其实是没有返回值的,拿一个变量来接收一个没有返回值的方法的返回值
  • 谁使用 extend 方法,就拼在谁的后面

使用“+=”拼接

a = [1, 2, 3, 4]  
b = [5, 6, 7, 8]  
a += b 
print(a)  
print(b)  
"""
运行结果
[1, 2, 3, 4, 5, 6, 7, 8]
[5, 6, 7, 8]
"""
  • extend 的效果是类似的
  • 但执行过程是不一样的
    • a += b 等价于 a = a + b;又创建了一个大列表,然后将小的装进去,再将大列表的值赋给 a 里面,最后将 a 的旧值释放
    • a.extend(b) 则是直接把 b 的内容拼到了 a 的后面,更高效,省去了数据拷贝和释放的过程

关于元组

创建元组

a = ()
b = tuple()
print(type(a))
print(type(b))"""
运行结果
<class 'tuple'>
<class 'tuple'>
"""

创建元组时指定初始值

a = (1, 2, 3, 4)
print(a)"""
运行结果
(1, 2, 3, 4)
"""

元组中的元素可以使任意类型

a = (1, 2, 'hello', True, [])
print(a)"""
运行结果
(1, 2, 'hello', True, [])
"""

通过下标进行访问

a = (1, 2, 3, 4, 5)
print(a[1])
print(a[-1])"""
运行结果
2
5
"""
  • 下标也是从 0 开始,len-1 结束
  • 当访问的下标超过 len - 1,会报错

切片

通过切片来获取元组中的一个部分

a = (1, 2, 3, 4)
print(a[1:3])
  • 这里的操作和列表是一摸一样的

遍历元组

a = (1, 2, 3, 4)
for elem in a:print(elem)
  • 和前面列表操作一样

查找元素

a = (1, 2, 3, 4, 5)
print(3 in a)
print(22 in a)
  • 和列表的操作一样

拼接元组

a = (1, 2, 3)
b = (4, 5, 6)
print(a + b)
  • 和列表的操作一样

为什么要有元组

在协同开发的时候,一个程序员 A 实现一些功能,提供给程序员 B 使用。A 写好一些函数,让 B 去调用
期间函数肯定要传参
B 在传参的时候就可能会纠结一个问题“我把我的参数传过去了,A 的函数里面是否会把我的参数的内容给改了呢”,如果使用元组作为参数,就可以避免这样的纠结

元组不可修改==>不可变对象

不可变对象,是可以哈希的

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

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

相关文章

ESP RainMaker OTA 自动签名功能的安全启动

【如果您之前有关注乐鑫的博客和新闻&#xff0c;那么应该对 ESP RainMaker 及其各项功能有所了解。如果不曾关注&#xff0c;建议先查看相关信息&#xff0c;知晓本文背景。】 在物联网系统的建构中&#xff0c;安全性是一项核心要素。乐鑫科技对系统安全给予了极高的重视。ES…

【C# 】使用List<实体类>

1. 使用List<实体类> 要在C#中使用List<EntityTemp>并实现查找数据输出&#xff0c;首先需要定义EntityTemp类&#xff0c;并创建一个List<EntityTemp>类型的列表。然后&#xff0c;你可以使用LINQ或其他方法来查找和输出数据。 假设EntityTemp类具有一个…

Transformer总结(三):组件介绍(位置编码,多头注意,残差连接,层归一化,基于位置的前馈网络)

文章目录 一、位置编码1.1 介绍1.2 简单探讨 二、多头注意力2.1 一般的多头注意力机制2.2 解码器中的掩码多头注意力机制&#xff08;Look-ahead Mask&#xff09; 三、残差连接四、层归一化4.1 对比不同的Normalization4.2 Batch Normalization的实现4.3 Layer Normalization的…

Variomes:支持基因组变异筛选的高召回率搜索引擎

《Bioinformatics》2022 Variomes&#xff1a; https://candy.hesge.ch/Variomes Source code&#xff1a; https://github.com/variomes/sibtm-variomes SynVar&#xff1a; https://goldorak.hesge.ch/synvar 文章摘要&#xff08;Abstract&#xff09; 动机&#xff08;Mot…

电子电气架构--- 智能汽车电子架构的核心诉求

我是穿拖鞋的汉子&#xff0c;魔都中坚持长期主义的汽车电子工程师。 老规矩&#xff0c;分享一段喜欢的文字&#xff0c;避免自己成为高知识低文化的工程师&#xff1a; 屏蔽力是信息过载时代一个人的特殊竞争力&#xff0c;任何消耗你的人和事&#xff0c;多看一眼都是你的不…

8.23工作感悟 关于div样式

一、关于div 样式嵌套在el-dialog框里面,如何让div框里面的东西&#xff0c;例如图片的大小不超出dialog框 首先对div框进行一个自定义class ‌div的class属性‌用于为div元素指定一个或多个类名&#xff0c;类名之间用空格分隔。类名可以在CSS样式表中使用&#xff0c;以定…

统计Statistics | AnyLogic 帮助

统计Statistics | AnyLogic 帮助 统计对象计算一系列数据样本的统计信息&#xff08;平均值、最小值、最大值等&#xff09;&#xff0c;数据类型为double。 根据数据被视为离散还是连续&#xff0c;对象的工作原理不同。 演示模型&#xff1a; 观测次数的统计函数打开AnyL…

【经验】linux下cuda的更换

linux下cuda的更换 查看当前cuda和cudnn的版本 nvcc -Vcudnn版本 cat /usr/local/cuda/include/cudnn.h | grep CUDNN_MAJOR -A 2下载对应版本的cuda 查看驱动版本535.54.03 下载对应的cuda版本 版本查看https://docs.nvidia.com/cuda/cuda-toolkit-release-notes/index.htm…

内存管理篇-02内存硬件电路和接口

1. 内存硬件实现机制 通过D触发器构建寄存器和内存的结构对比,这里主要先表达sram复杂&#xff0c;dram简单。 2. sram和ddr sdram结构图对比 主要是想对比sram和dram在和CPU连接过程的差异。sram需要的地址线较多&#xff0c;dram需要的较少&#xff0c;但是需要多次发送&…

货车制造5G智能工厂工业物联数字孪生平台,推进制造业数字化转型

货车制造5G智能工厂工业物联数字孪生平台&#xff0c;推进制造业数字化转型。随着5G技术的飞速发展与工业物联网的深度融合&#xff0c;货车制造5G智能工厂工业物联数字孪生平台应运而生&#xff0c;它不仅重新定义了生产模式&#xff0c;更以强大的技术驱动力&#xff0c;推动…

[数据集][目标检测]电力场景输电线防震锤检测数据集VOC+YOLO格式2721张2类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;2721 标注数量(xml文件个数)&#xff1a;2721 标注数量(txt文件个数)&#xff1a;2721 标注…

武汉流星汇聚:亚马逊领跑全球电商,中国卖家迎来前所未有机遇窗口

在数字经济的浪潮中&#xff0c;亚马逊如同一艘巨轮&#xff0c;乘风破浪&#xff0c;引领着全球电商行业的航向。其每月近30亿次的访问量&#xff0c;不仅彰显了其在全球市场的强大影响力&#xff0c;更为中国卖家提供了前所未有的发展机遇。在这个平台上&#xff0c;中国卖家…

Unity URP Shader 修改深度让人物不再被地面遮挡

Unity URP Shader 修改深度让人物不再被地面遮挡 前言项目场景布置代码编写 前言 遇到一个小问题&#xff0c;人物总是被XY平面的地面遮挡&#xff0c;于是在Shader中改一下深度输出&#xff0c;这样地面再也不会挡住人物了。 项目 场景布置 将人物放到XY平面的后面 配置S…

【论文分享】Graviton: Trusted Execution Environments on GPUs 2018’OSDI

目录 AbstractIntroductioncontributions BackgroundGPUSoftware stackHardwareContext and channel managementCommand submissionProgramming modelInitializationMemory allocationHost-GPU transfersKernel dispatch Sharing Intel SGX Threat ModelOverviewGraviton Archi…

设计模式笔记01(java版)

文章目录 设计模式概述学习设计模式的必要性设计模式分类创建型模式结构型模式行为型模式 UML类图概述类图的作用类图表示法类的表示方式类与类之间关系的表示方式1&#xff0c;单向关联2&#xff0c;双向关联3&#xff0c;自关联聚合关系组合关系依赖关系继承关系实现关系 软件…

Pytorch 张量运算函数(补充)

mean() mean()函数是进行张量均值计算的函数,常用参数可以设置参数dim来进行对应维度的均值计算 以下是使用一个二维张量进行演示的例子 import numpy as np import torch device torch.device(mps if torch.backends.mps.is_available() else cpu) print(device ) data1 …

C++ | Leetcode C++题解之第367题有效的完全平方数

题目&#xff1a; 题解&#xff1a; class Solution { public:bool isPerfectSquare(int num) {double x0 num;while (true) {double x1 (x0 num / x0) / 2;if (x0 - x1 < 1e-6) {break;}x0 x1;}int x (int) x0;return x * x num;} };

linux系统,ubuntu安装英伟达NVIDIA4090显卡驱动

文章目录 前言下载英伟达NVIDIA官方驱动安装NVIDIA驱动远程安装关闭交互界面设置权限&#xff08;自己确认版本号5&#xff09;安装&#xff08;自己确认版本号5&#xff09;打开交互界面&#xff0c;并重启系统验证是否安装成功 异常处理问题1问题2问题3&#xff08;可能没解决…

python小游戏——躲避球(可当课设)

游戏简介&#xff1a; 没有美术&#xff0c;画面简洁&#xff08;懒得做&#xff09;。玩家控制小球躲避敌人&#xff08;上下左右&#xff0c;闪避&#xff09;&#xff0c;敌人体积越大速度越慢&#xff0c;随机生成道具球&#xff08;目前只有生命球&#xff09;&#xff0…

​14:00面试,14:06就出来了,问的问题有点变态。。。

从小厂出来&#xff0c;没想到在另一家公司又寄了。 到这家公司开始上班&#xff0c;加班是每天必不可少的&#xff0c;看在钱给的比较多的份上&#xff0c;就不太计较了。没想到5月一纸通知&#xff0c;所有人不准加班&#xff0c;加班费不仅没有了&#xff0c;薪资还要降40%…