Py列表(list)

目录

正向索引:

反向索引:

嵌套列表:

 修改列表中的值

列表常用的方法

实例

练习:


正向索引

从0开始,依次递增。第一个元素的索引为0,第二个元素的索引为1,依此类推。

列表的下标索引(正向)

例如:

fruits = ['apple', 'banana', 'cherry']
print(fruits[0])  # 输出 'apple'
print(fruits[1])  # 输出 'banana'

反向索引

从-1开始,依次递减。最后一个元素的索引为-1,倒数第二个元素的索引为-2,以此类推。

列表的下标索引(反向)

例如:

print(fruits[-1])  # 输出 'cherry'
print(fruits[-2])  # 输出 'banana'

嵌套列表:

最底层的列表被标记为"元素0"、"元素1"、"元素0"和"元素1",这些元素分别属于两个不同的列表,即"列表(list)"0和"列表(list)"1。这两个列表又作为元素存在于最上层的"列表(list)"中。

# 创建一个嵌套列表
nested_list = [[1, 2], [3, 4]]# 访问嵌套列表中的元素
print(nested_list[0][0])  # 输出: 1
print(nested_list[0][1])  # 输出: 2
print(nested_list[1][0])  # 输出: 3
print(nested_list[1][1])  # 输出: 4

最底层的列表被标记为"元素0"、"元素1"、"元素0"和"元素1",这些元素分别属于两个不同的列表,即"列表(list)"0和"列表(list)"1。这两个列表又作为元素存在于最上层的"列表(list)"中。

线性表(常见的线性表-----数组 栈 队列 链表) ---- 基于链表的数据结构实现的

注意:python里面是没有数组的 数组的存储空间是连续的,它删除比较麻烦,因为内存是连续的,查询速度特别快(因为是连续的)-----------增删改的效率比较低

栈:先进后出,后进先出

队列:先进先出,后进后出

链表(比较特殊的数据结构):(只有一个6byte的空间,但是要存8byte的数组,肯定是不够的,所以是有很多零碎的内存块,科学家就使用线将各种零碎的内存块连接起来)

单向链表:节约内存

没有头节点,只有尾节点

双向链表

一般有三个节点,第一个节点存上一个节点的地址(头指针),中间的存储数据,最后一个存下一个节点的内存(尾指针)

Python中的列表就是基于双向链表实现的(查询慢,增删快)

  • 定义

    由弱数据类型语言决定,直接赋值给变量

    如: ls = [ 2,3,4,5 ]

    使用全局函数list对列表进行定义

     ls = list()
    ​ls = list([1,2,3,4,5,""])
    ​#容器中的每一个值,我们叫做元素
  • 如何访问元素

    使用下标来访问,注意下标是从0开始的(外国人喜欢从0开始计数) ls[0] 如果下标超过范围会报异常, 可以用下标来访问值,也可以修改值,另外下标也可以是负数

    求列表的长度?

    全局函数len(容器) -----------返回容器的长度

  • 如何遍历容器

     For循环For i in ls:Print(i)
    ​While循环Index = 0While index < len(ls):Print(ls[index])Index += 1

     修改列表中的值

    示例 1:修改列表中特定位置的值

    假设有一个列表,你想修改其中某个位置的元素。

    fruits = ['apple', 'banana', 'cherry']
    # 修改索引为1的元素,即把'banana'改为'orange'
    fruits[1] = 'orange'
    print(fruits)  # 输出: ['apple', 'orange', 'cherry']

    示例 2:遍历列表并修改所有值

    如果想要基于某种条件或运算修改列表中的每一个元素,可以遍历列表。

    numbers = [1, 2, 3, 4, 5]
    # 将列表中的每个元素都平方
    for i in range(len(numbers)):numbers[i] = numbers[i] ** 2
    print(numbers)  # 输出: [1, 4, 9, 16, 25]

    或者使用列表推导式更简洁地实现同样的功能:

    numbers = [1, 2, 3, 4, 5]
    squared_numbers = [x ** 2 for x in numbers]
    print(squared_numbers)  # 输出: [1, 4, 9, 16, 25]

    示例 3:修改嵌套列表中的值

    对于嵌套列表(列表中的列表),你需要通过两层索引来访问和修改内部列表的元素。

    nested_list = [[1, 2], [3, 4]]
    # 修改嵌套列表中第二个列表的第一个元素
    nested_list[1][0] = 'changed'
    print(nested_list)  # 输出: [[1, 2], ['changed', 4]]

列表常用的方法

方法名

含义
append()向列表尾部追加元素
insert(index, object)向指定的位置追加元素
sort()列表排序(只能排Int)字母按照ASCII值进行排序,类型不能混淆
index()查找元素第一次在列表中出现的位置,如果没有这个元素则会
reverse()将列表元素顺序翻转
remove()通过元素来移除元素,如果元素不存在则抛出异常
count()统计元素在列表中的个数
clear()清除元素
copy()浅拷贝对象(拷贝) 不等价于 = (引用传递),在堆内存中进行对象拷贝
extend()合并列表
pop()与append()相反,删除列表最后一个元素,并返回值这个元素,要删除指定位置的元素,用pop(i)方法,其中i是索引位置

实例

下面是一些关于如何使用 Python 列表方法的例子:

append() 方法:向列表尾部追加元素。

my_list = [1, 2, 3]
my_list.append(4)  # 添加元素 4 到列表末尾
print(my_list)  # 输出: [1, 2, 3, 4]

insert(index, object) 方法:向指定的位置追加元素。

my_list = [1, 2, 3, 4, 5]
my_list.insert(2, "new_element")  # 在索引 2 的位置插入元素
print(my_list)  # 输出: [1, 2, 'new_element', 3, 4, 5]

sort() 方法:列表排序(只能排Int)字母按照ASCII值进行排序,类型不能混淆。

my_list = [5, 1, 9, 3, 7]
my_list.sort()  # 对列表进行升序排列
print(my_list)  # 输出: [1, 3, 5, 7, 9]# 注意:对于非数字类型的元素,需要自定义比较函数或使用 sorted() 函数

index(element) 方法:查找元素第一次在列表中出现的位置,如果没有这个元素则抛出异常。

my_list = [1, 2, 3, 4, 5]
print(my_list.index(3))  # 输出: 2

reverse() 方法:将列表元素顺序翻转。

my_list = [1, 2, 3, 4, 5]
my_list.reverse()
print(my_list)  # 输出: [5, 4, 3, 2, 1]

remove(element) 方法:通过元素来移除元素,如果元素不存在则抛出异常。

my_list = [1, 2, 3, 4, 5]
my_list.remove(3)  # 移除元素 3
print(my_list)  # 输出: [1, 2, 4, 5]

count(element) 方法:统计元素在列表中的个数。

my_list = [1, 2, 3, 2, 1]
print(my_list.count(2))  # 输出: 2

clear() 方法:清除元素。

my_list = [1, 2, 3, 4, 5]
my_list.clear()
print(my_list)  # 输出: []

copy() 方法:浅拷贝对象(拷贝)不等于 = (引用传递),在堆内存中进行对象拷贝。

my_list = [1, 2, 3]
copied_list = my_list.copy()
print(copied_list)  # 输出: [1, 2, 3]

extend(iterable) 方法:合并列表。

my_list1 = [1, 2, 3]
my_list2 = [4, 5, 6]
my_list1.extend(my_list2)
print(my_list1)  # 输出: [1, 2, 3, 4, 5, 6]

pop([index]) 方法:与append()相反,删除列表最后一个元素,并返回值这个元素,要删除指定位置的元素,用pop(i)方法,其中i是索引位置。

my_list = [1, 2, 3, 4, 5]
print(my_list.pop())  # 输出: 5
print(my_list)  # 输出: [1, 2, 3, 4]my_list.pop(2)  # 删除索引为 2 的元素
print(my_list)  # 输出: [1, 2, 4]

练习:

使用Python列表实现学生年龄管理

在本篇博客中,我们将探讨如何使用Python的列表功能来处理与学生年龄相关的一系列任务。以下是我们的目标:

  • 定义一个学生年龄列表。
  • 在列表末尾追加元素。
  • 向列表末尾追加另一个列表。
  • 获取列表的第一个和最后一个元素。
  • 查找指定元素在列表中的索引位置。
  • 对列表进行排序。

初始化一个包含若干学生年龄的列表:

 
student = [21, 25, 21, 23, 22, 20]

模拟新学生加入班级的情景,我们使用append()方法向列表尾部添加一名31岁的学生年龄:

student.append(31)
print(student)  # 输出当前列表状态
# 输出: [21, 25, 21, 23, 22, 20, 31]

如果有多个学生同时加入,可以利用extend()方法将一个包含多个人年龄的列表合并进来。这里,新增了三位学生,年龄分别为29、33、30岁:

student_new = [29, 33, 30]
student.extend(student_new)
print(student)  # 输出: [21, 25, 21, 23, 22, 20, 31, 29, 33, 30]

在管理过程中,可能需要移除列表中的元素。这里,分别移除了最年轻(索引为0)和最新加入(索引为-1)的学生年龄,并打印移除的值:

num = student.pop(0) # 输出: 21 (移除并打印元素)
print(num)
num = student.pop(-1)  # 输出: 30 (移除并打印元素)
print(num)

为了查找特定学生年龄的位置,比如刚加入的31岁学生,我们使用index()方法获取其索引:

print(student.index(31))  # 输出: 6 (显示31在列表中的索引位置)

最后,为了便于分析或进一步处理,对整个年龄列表进行排序,保持数据有序:

student.sort()
print(student)  # 输出: [20, 21, 21, 22, 23, 25, 29, 31, 33] (列表按升序排列)

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

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

相关文章

视频太大怎么压缩变小 视频太大了怎么压缩

视频作为一种多媒体形式&#xff0c;在当今社会的重要性日益凸显&#xff0c;其应用范围广泛&#xff0c;影响力深远。 但是视频文件的大小也在不断增加&#xff0c;这给存储和传输带来了很大的困扰。那么&#xff0c;当视频文件过大时&#xff0c;我们该如何将其压缩变小呢&am…

左偏树,可合并堆

合并两个堆并维护最小或最大性质解决树上节点问题&#xff0c;从叶节点往根维护&#xff0c;每个节点看作一个堆表示到最近的叶节点的距离&#xff0c;所以每次对合并&#xff08;树高矮&#xff09;表示堆的顶点对应下标关键代码 static void dfs(int x){for(int ihead[x];i&g…

全域运营是本地生活服务的新模式吗?

最近&#xff0c;本地生活赛道又出现了一个新的说法&#xff0c;即全域运营是本地生活的下半场。事实上&#xff0c;这一论断并非空穴来风&#xff0c;而是有真凭实据。 作为多家互联网大厂重点布局的业务板块&#xff0c;本地生活的火爆程度早已有目共睹。根据多家互联网大厂…

互联网的利

在互联网没发明之前&#xff0c;人类说话要近距离的说&#xff0c;玩游戏要近距离的玩&#xff0c;十分麻烦。于是&#xff0c;互联网解决了这个问题。聊天可以在电脑上聊&#xff0c;玩游戏可以用游戏软件查找玩家来玩&#xff0c;实现了时时可聊&#xff0c;时时可玩的生活。…

nginx编译安装手把手教学

编译安装nginx的第一步需要从nginx的官网找到nginx最新的稳定版本 下面这是官方网站的资源下载地址 https://nginx.org/en/download.html选中稳定版本点击右键——选择复制链接 在终端内使用wget指令官网下载地址&#xff0c;将nginx下载 使用wget指令下载 wget https://ng…

代码模板,Cookie和Session

目录 代码模板 Cookie的基本使用 概念 Cookie的API public Cookie(String name, String value) 发送Cookie对象到客户端&#xff1a;使用response对象 创建Cookie对象并响应给浏览器 在服务器后端获取Cookie对象 Cookie[]cookiesrequset.getCookies(); Cookie的使用细…

【InternLM实战营第二期笔记】03:“茴香豆“,搭建你的 RAG 智能助理(未完成)

文章目录 笔记-RAG课程结构为什么要用 RAG&#xff1f;定义工作原理向量数据库RAG 工作流程发展历程常见优化RAG vs 微调LLM 优化方法比较RAG的评价总结 笔记-茴香豆什么是茴香豆茴香豆实战 笔记-RAG 课程结构 为什么要用 RAG&#xff1f; 新增知识&#xff0c;尤其是高频变动…

基于51单片机简易温度计

一.硬件方案 本系统利用51单片机控制温度传感器DS18B20进行温度的实时检测并显示&#xff0c;能够实现快速测量环境温度。硬件以微控制器为核心&#xff0c;外接时钟电路、复位电路、温度测量电路、LED显示电路组成。 二.设计功能 &#xff08;1&#xff09;采用DS18B20温度…

Node.js和npm常用命令

一、Node.js简介 Node.js是一个免费、开源、跨平台的JavaScript运行时环境&#xff0c;允许开发人员创建服务器、web应用程序、命令行工具和脚本。 点击查看node.js中文官网 点击查看node.js英文官网 二、npm简介 npm(Node Package Manager)是Node.js的软件包管理器&#xff0…

ssm150旅游网站的设计与实现+jsp

旅游网站设计与实现 摘 要 现代经济快节奏发展以及不断完善升级的信息化技术&#xff0c;让传统数据信息的管理升级为软件存储&#xff0c;归纳&#xff0c;集中处理数据信息的管理方式。本旅游网站就是在这样的大环境下诞生&#xff0c;其可以帮助管理者在短时间内处理完毕庞…

工作纪实50-Idea下载项目乱码

下载了公司的一份项目代码&#xff0c;发现是gbk格式的&#xff0c;但是我的日常习惯又是utf-8&#xff0c;下载项目以后全是乱码&#xff0c;一脸懵 借用网友的一张图&#xff0c;如果是一个一个文件这么搞&#xff0c;真的是费劲&#xff0c;好几百个文件&#xff01; 步骤…

NSS‘题目练习3

[SWPUCTF 2021 新生赛]easyupload3.0 打开题目发现要求上传.jpg文件 先上传抓包&#xff0c;尝试更改后缀 换一种形式 文件头绕过 都试过之后尝试上传.htaccess文件&#xff0c;发现上传成功 会将之后上传的文件后缀自动更名为.php 再上传.jpg文件 蚁剑连接找到flag [SWPUCTF …

保障餐饮场所安全:可燃气体报警器专业检测的必要性

在餐饮行业&#xff0c;火灾隐患一直是备受关注的问题。为了有效预防和及时发现可燃气体泄漏&#xff0c;可燃气体报警器的专业检测周期显得尤为重要。 今天&#xff0c;佰德和大家一起来深入了解一下可燃气体报警器的专业检测周期&#xff0c;若您对此有不同的观点或其他的问…

K8S集群监控方案之Prometheus+kube-state-metrics+Grafana

序言 | Prometheus 中文文档 方案简单架构图 一、部署kube-state-metrics 1、部署文件下载 地址 kube-state-metrics/examples/standard at main kubernetes/kube-state-metrics GitHub 2、修改下载的文件 2.1、修改镜像 原镜像可能下载不了&#xff0c;这里修改deploy…

苹果与OpenAI合作在即:iOS 18中的ChatGPT引发期待与担忧

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…

互联网应用主流框架整合之数据库事务管理

在互联网系统中同时运行着成千上百个线程是十分常见的事情&#xff0c;尤其当一个热门出现时&#xff0c;用户几乎同时打开手机、电脑、平板灯设备进行访问&#xff0c;这样就会导致数据库处在一个多事务访问的环境中&#xff0c;从而引发数据丢失或者数据不一致的现象&#xf…

计算机考研|408开始的晚,如何规划复习?

408开始的比较晚不用怕 只需要6个月的复习时间&#xff0c;按照我的复习计划&#xff0c;你至少可以考100这个分数 我的计划是对于基础差的考生的&#xff0c;大佬们就可以绕道了&#xff0c;对于基础差的考生来说&#xff0c;408复习的难点其实在于学好数据结构和计算机组成…

rk3568_semaphore

文章目录 前言1 什么是信号量1.1 信号量API函数2、信号量实验2.1 实验目的2.2函数源码2.3 运行结果图前言 本文记录rk3568开发板的信号量实验 1 什么是信号量 信号量是同步的一种方式,常常用于控制对共享资源的访问。 举个例子:停车场的停车位有100个,这100个停车位就是共…

【Python】 如何将列表转换为字符串

基本原理 在Python中&#xff0c;列表&#xff08;list&#xff09;和字符串&#xff08;string&#xff09;是两种不同的数据类型。列表是一个有序的元素集合&#xff0c;可以包含不同类型的元素&#xff0c;而字符串则是一个字符序列。有时&#xff0c;我们可能需要将列表中…

【chagpt】广泛使用API之前:考虑成本和数据隐私

文章目录 一. 定价和标记限制二. 安全和隐私 在广泛使用API之前&#xff0c;应该考虑两个重要因素&#xff1a;成本和数据隐私。 一. 定价和标记限制 OpenAI在Pricing页面上列出了模型的定价。请注意&#xff0c;OpenAI不一定及时更新该页面上的定价信息&#xff0c;因此实际…