【100天精通python】Day7:数据结构_列表 List的创建、删除、访问、遍历、统计、排序、推导等使用

目录

1 列表的创建

2 列表的删除

3 访问列表元素

4 遍历列表

5 添加修改删除列表元素

6 对列表进行统计和计算

7 对列表进行排序

8 列表推导式

9 多维列表


  

        在Python中,列表是一种有序的可变数据类型,用于存储一组元素。

        列表使用方括号“[] ”来定义,其中的元素可以是任意数据类型,包括数字、字符串、布尔值、其他列表等。

        列表中的元素之间用逗号 “, ”分隔。

1 列表的创建

1.1 创建空列表

empty_list = []

1.2 创建包含元素的列表

numbers = [1, 2, 3, 4, 5]
fruits = ["apple", "banana", "orange"]
mixed_data = [1, "hello", True, 3.14]

1.3 使用list()函数创建列表

numbers = list(range(1, 6))  # 创建一个包含1到5的整数列表

1.4 使用列表解析(List Comprehension)创建列表

squares = [x**2 for x in range(1, 6)]  # 创建一个包含1到5的平方的列表,即[1, 4, 9, 16, 25]

1.5 创建嵌套列表 

nested_list = [[1, 2, 3], ["a", "b", "c"], [True, False]]

注意:列表中的元素可以是任意数据类型,而且列表长度可以根据需要动态调整,因为列表是可变的。可以通过索引来访问列表中的元素,也可以使用切片来获取子列表。例如:

my_list = [1, 2, 3, 4, 5]# 访问列表中的元素
print(my_list[0])  # 输出:1
print(my_list[2])  # 输出:3# 使用切片获取子列表
subset = my_list[1:4]  # subset变量将包含列表中索引为1到3的元素,即[2, 3, 4]

2 列表的删除

2.1 清空列表所有元素

my_list = [1, 2, 3, 4, 5]my_list.clear()  # 清空my_list,即变为一个空列表:[]

2.2 删除整个列表 

my_list = [1, 2, 3, 4, 5]del my_list  # 删除整个列表

 请注意,上述操作是对原始列表进行的更改。如果需要保留原始列表并创建一个新的列表,可以使用切片或列表解析来实现。例如:

my_list = [1, 2, 3, 4, 5]new_list = my_list[:2] + my_list[3:]  # 创建一个新列表,删除索引为2的元素,即[1, 2, 4, 5]

3 访问列表元素

要访问列表元素,可以使用索引或切片。

3.1 使用索引访问单个元素

        列表中的元素按照从左到右的顺序分配索引,从0开始计数。可以使用索引来访问列表中的单个元素。

my_list = [10, 20, 30, 40, 50]first_element = my_list[0]  # 获取第一个元素,索引为0
second_element = my_list[1]  # 获取第二个元素,索引为1
third_element = my_list[2]  # 获取第三个元素,索引为2print(first_element)  # 输出:10
print(second_element)  # 输出:20
print(third_element)  # 输出:30

3.2 使用负数索引访问倒数元素

        使用负数索引来访问列表中的倒数元素,即从列表末尾开始计数

my_list = [10, 20, 30, 40, 50]last_element = my_list[-1]  # 获取最后一个元素,索引为-1
second_last_element = my_list[-2]  # 获取倒数第二个元素,索引为-2print(last_element)  # 输出:50
print(second_last_element)  # 输出:40

3.3 使用切片访问多个元素

        切片允许获取列表中的多个元素,可以指定起始索引和结束索引来创建一个切片。

my_list = [10, 20, 30, 40, 50]slice_of_list = my_list[1:4]  # 获取索引1到索引3的元素,不包括索引4
print(slice_of_list)  # 输出:[20, 30, 40]

4 遍历列表

        遍历列表是指按顺序访问列表中的每个元素,以执行相同或类似的操作。在Python中,有几种方法可以遍历列表。

4.1 使用for循环遍历列表元素

        使用for循环是最常见和简单的遍历列表的方法。它可以依次获取列表中的每个元素,并对每个元素执行指定的操作。

my_list = [10, 20, 30, 40, 50]for item in my_list:print(item)  # 输出列表中的每个元素,依次打印:10 20 30 40 50

4.2 使用while循环和索引遍历列表元素

        使用while循环和索引可以手动遍历列表中的元素。在这种情况下,需要使用一个索引变量来控制循环。

my_list = [10, 20, 30, 40, 50]index = 0
while index < len(my_list):print(my_list[index])  # 输出列表中的每个元素,依次打印:10 20 30 40 50index += 1

 4.3  使用enumerate()函数同时获取索引和元素

        enumerate()函数可以在遍历列表时同时获取元素和对应的索引。

my_list = [10, 20, 30, 40, 50]for index, item in enumerate(my_list):print(f"Index: {index}, Element: {item}")  # 输出:Index: 0, Element: 10  Index: 1, Element: 20 ...

5 添加修改删除列表元素

        在Python中,可以通过索引来添加和修改列表元素。

5.1 添加元素

        a) 使用append()方法:append()方法用于在列表的末尾添加一个元素。

my_list = [10, 20, 30]my_list.append(40)
print(my_list)  # 输出:[10, 20, 30, 40]# 也可以一次性添加多个元素,通过使用extend()方法:
my_list.extend([50, 60])
print(my_list)  # 输出:[10, 20, 30, 40, 50, 60]

        b) 使用insert()方法:insert()方法用于在指定索引处插入一个元素。 

my_list = [10, 20, 30]my_list.insert(1, 15)  # 在索引1处插入元素15
print(my_list)  # 输出:[10, 15, 20, 30]

5.2 修改元素

        通过索引访问列表中的元素,并用新的值替换它,即可修改列表元素。

my_list = [10, 20, 30]my_list[1] = 25  # 将索引1处的元素20修改为25
print(my_list)  # 输出:[10, 25, 30]

 5.3 删除元素

 5.3.1 使用del关键字删除列表中的元素

my_list = [1, 2, 3, 4, 5]del my_list[2]  # 删除索引为2的元素,此时my_list变为[1, 2, 4, 5]

5.3.2 使用remove()方法删除特定值的元素

my_list = [1, 2, 3, 4, 5]my_list.remove(3)  # 删除值为3的元素,此时my_list变为[1, 2, 4, 5]

5.3.3 使用pop()方法删除指定索引的元素并返回该元素

my_list = [1, 2, 3, 4, 5]removed_element = my_list.pop(2)  # 删除索引为2的元素(值为3)并将其赋值给removed_element,此时my_list变为[1, 2, 4, 5]

5.3.4 使用切片来删除多个元素

my_list = [1, 2, 3, 4, 5]my_list = my_list[:2] + my_list[3:]  # 删除索引为2的元素(值为3),此时my_list变为[1, 2, 4, 5]

6 对列表进行统计和计算

        对列表进行统计和计算,例如求和、找最大值和最小值、计算平均值等。以下是一些常用的列表统计和计算方法:

6.1 求和:

        使用sum()函数计算列表中所有元素的和。

my_list = [1, 2, 3, 4, 5]total_sum = sum(my_list)
print(total_sum)  # 输出:15

 6.2 最大值和最小值:

  • 使用max()函数找到列表中的最大值。
  • 使用min()函数找到列表中的最小值。
  • my_list = [1, 2, 3, 4, 5]max_value = max(my_list)
    min_value = min(my_list)print(max_value)  # 输出:5
    print(min_value)  # 输出:1
    

6.3 平均值:

  • 使用sum()len()函数结合起来计算列表的平均值。
  • my_list = [1, 2, 3, 4, 5]average_value = sum(my_list) / len(my_list)
    print(average_value)  # 输出:3.0
    

6.4 统计元素个数:

  • 使用len()函数获取列表中元素的总数。
my_list = [1, 2, 3, 4, 5]element_count = len(my_list)
print(element_count)  # 输出:5

7 对列表进行排序

7.1 使用sort()方法:

  sort()方法用于在原地对列表进行排序,即修改原始列表。排序后,原始列表会被改变,而不是创建一个新的排序后的副本。

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

7.2  使用sorted()函数:

   sorted()函数用于对列表进行排序并返回一个新的排序后的列表,而不会修改原始列表。

my_list = [3, 1, 4, 2, 5]
sorted_list = sorted(my_list)print(sorted_list)  # 输出:[1, 2, 3, 4, 5]
print(my_list)  # 输出:[3, 1, 4, 2, 5](原始列表不变)

7.3  自定义排序规则:

        使用sort()方法或sorted()函数的key参数来指定自定义的排序规则。

# 按绝对值进行排序
my_list = [-3, 1, -4, 2, -5]
my_list.sort(key=abs)print(my_list)  # 输出:[1, 2, -3, -4, -5]
# 按字符串长度进行排序
my_list = ['apple', 'banana', 'orange', 'kiwi']
my_list.sort(key=len)print(my_list)  # 输出:['kiwi', 'apple', 'banana', 'orange']

 注意:对于复杂对象的列表,您可以使用key参数指定一个函数,该函数会返回用于排序的关键值。排序将根据这些关键值进行。如果您使用sort()方法进行原地排序,请注意原始列表将被修改,而不会返回新的排序后的列表。而使用sorted()函数则会返回一个新的排序后的列表,而不会修改原始列表。

8 列表推导式

        列表推导式是一种简洁的语法,用于创建新的列表。它允许您通过在一行代码中定义列表的元素,并根据一定的规则对现有的列表或其他可迭代对象进行转换和过滤。

        列表推导式的基本形式是:

[expression for item in iterable if condition]

其中:

  • expression 是一个表达式,用于定义新列表中的元素;
  • item 是来自可迭代对象的每个元素;
  • iterable 是一个可迭代对象,比如列表、元组、集合等;
  • condition 是一个可选的条件,用于过滤可迭代对象中的元素。

下面是一些使用列表推导式的示例:

8.1 创建一个包含1到10的平方的列表:

squares = [x**2 for x in range(1, 11)]
print(squares)  # 输出:[1, 4, 9, 16, 25, 36, 49, 64, 81, 100]

8.2  过滤出列表中的偶数:

numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
even_numbers = [x for x in numbers if x % 2 == 0]
print(even_numbers)  # 输出:[2, 4, 6, 8, 10]

 8.3 将字符串列表中的元素转换为大写:

words = ['hello', 'world', 'python']
upper_words = [word.upper() for word in words]
print(upper_words)  # 输出:['HELLO', 'WORLD', 'PYTHON']

8.4 使用条件表达式进行元素转换:

numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
squared_or_negative = [x**2 if x % 2 == 0 else -x for x in numbers]
print(squared_or_negative)  # 输出:[-1, 4, -3, 16, -5, 36, -7, 64, -9, 100]

9 多维列表

        多维列表是指包含多个嵌套列表的列表,也可以称为二维列表、三维列表等,根据嵌套层数而定。在Python中,您可以使用列表的列表来表示多维列表,其中每个元素是一个子列表。这样的列表可以形成一个类似于矩阵或二维数组的结构,它在数据处理和存储方面非常有用。

        下面是一个二维列表的示例:

matrix = [[1, 2, 3],[4, 5, 6],[7, 8, 9]
]

在这个示例中,matrix 是一个包含三个子列表的列表,每个子列表代表一行。您可以使用索引访问多维列表中的元素,例如 matrix[0][1] 将返回 2,表示第一行第二列的元素。

您还可以使用嵌套的列表推导式来创建多维列表。例如,以下代码创建一个3x3的全零二维列表:

rows = 3
cols = 3
matrix = [[0 for _ in range(cols)] for _ in range(rows)]
print(matrix)  # 输出:[[0, 0, 0], [0, 0, 0], [0, 0, 0]]

 同样,您可以创建更高维度的列表,只需在嵌套层级上增加更多的列表。

例如,以下代码创建一个三维列表

x = 3
y = 3
z = 3
three_dimensional_list = [[[0 for _ in range(z)] for _ in range(y)] for _ in range(x)]
print(three_dimensional_list)
# 输出:[[[0, 0, 0], [0, 0, 0], [0, 0, 0]], [[0, 0, 0], [0, 0, 0], [0, 0, 0]], [[0, 0, 0], [0, 0, 0], [0, 0, 0]]]

多维列表在处理各种数据结构和算法问题时非常有用,特别是在图像处理、矩阵运算和游戏开发等领域。

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

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

相关文章

Qt5.14.2下载及安装

1. 下载 https://download.qt.io/archive/qt/5.14/5.14.2/ 由于Qt 自从5.15版本开始&#xff0c;对非商业版本&#xff08;也就是开源版本&#xff09;&#xff0c;不提供已经制作好的离线exe安装包。所以&#xff0c;对于5.15&#xff08;含&#xff09;之后的版本&#xff…

Idea 设置类和方法的注释(获取参数)

Idea 添加注释&#xff1a;类注释、方法注释 类注释 方法注释 类注释 File–Setting–Editor–File and Code Templates–Class: 注释模板&#xff1a; /** **description: *author: fqtang*time: ${DATE} ${TIME}* */ 操作截图&#xff1a; 效果&#xff1a; 方法注释 为了…

图数据库Neo4j学习二——cypher基本语法

1命名规范 名称应以字母字符开头&#xff0c;不以数字开头&#xff0c;名称不应包含符号&#xff0c;下划线除外可以很长&#xff0c;最多65535( 2^16 - 1) 或65534字符&#xff0c;具体取决于 Neo4j 的版本名称区分大小写。:PERSON和:Person是:person三个不同的标签&#xff…

Jmeter+Jenkins+Ant自动化持续集成环境搭建

一、安装准备 1.JDK:jdk-8u121-windows-x64 2.jmeter工具&#xff1a;apache-jmeter-2.13 3.ANT工具&#xff1a;apache-ant-1.9.7-bin 4.jenkins工具&#xff1a;jenkins-2.32.2 二、软件安装 1.JDK的安装 >双击JDK安装包&#xff0c;选择安装路径&#xff08;本人是…

详细总结Webpack5的配置和使用

打包工具 使用框架&#xff08;React、Vue&#xff09;&#xff0c;ES6 模块化语法&#xff0c;Less/Sass 等 CSS预处理器等语法进行开发的代码要想在浏览器运行必须经过编译成浏览器能识别的 JS、CSS 等语法&#xff0c;才能运行。 所以需要打包工具帮我们做完这些事。除此之…

3、C# 方法构成

上一节,我们讲述了程序的基本构成。由大到小分别为”解决方案-->项目-->类-->方法“。 这一节,我们讲讲方法。 方法可以说是程序的基本构成单位。假如把方法抽象成点的话,我们可以认为程序是一个树状的结构。树根,就是我们的起点方法,也叫主方法。这一点,基本…

决策树(Decision Tree)

决策树的原理 决策树算法是一种基于树结构的分类和回归算法。它通过对数据集进行递归地分割&#xff0c;构建一个树形模型&#xff0c;用于预测目标变量的值。 决策树的构建过程基于以下原理&#xff1a; 1. 特征选择&#xff1a;选择最佳的特征来进行数据集的分割。常用的…

堆排序与直接选择排序

目录 一、直接选择排序 1.基本思想 2.直接选择排序的特性总结 3.代码实现&#xff1a; 二、堆排序 1. 概念&#xff1a; 2.图像实现&#xff1a; 3.代码实现&#xff1a; 一、直接选择排序 1.基本思想 每一次从待排序的数据元素中选出最小&#xff08;或最大&#xff09…

MySQL多表连接查询练习

准备工作 创建student表 CREATE TABLE student ( id INT(10) NOT NULL UNIQUE PRIMARY KEY , name VARCHAR(20) NOT NULL , sex VARCHAR(4) , birth YEAR, department VARCHAR(20) , address VARCHAR(50) );创建score表 CREATE TABLE score ( id INT(10) NOT …

NetSuite ERP顾问的进阶之路

目录 1.修养篇 1.1“道”是什么&#xff1f;“器”是什么&#xff1f; 1.2 读书这件事儿 1.3 十年计划的力量 1.3.1 一日三省 1.3.2 顾问损益表 1.3.3 阶段课题 2.行为篇 2.1协作 2.2交流 2.3文档管理 2.4时间管理 3.成长篇 3.1概念能力 3.1.1顾问的知识结构 …

大数据学习05-Kafka分布式集群部署

系统环境&#xff1a;centos7 软件版本&#xff1a;jdk1.8、zookeeper3.4.8、hadoop2.8.5 本次实验使用版本 kafka_2.12-3.0.0 一、安装 Kafka官网 将安装包上传至linux服务器上 解压 tar -zxvf kafka_2.12-3.0.0.tgz -C /home/local/移动目录至kafka mv kafka_2.12-3.0…

护城河理论

护城河理论 护城河理论|来自股神巴菲特&#xff0c;是指投资的企业在某一方面的核心竞争力。 模型介绍 在2000年的伯克希尔哈撒韦的年会上&#xff0c;巴菲特说&#xff1a;让我们来把护城河作为一个伟大企业的首要标准&#xff0c;保持它的宽度&#xff0c;保持它不被跨越。我…

听GPT 讲K8s源代码--pkg(五)

在 Kubernetes 中&#xff0c;kubelet 是运行在每个节点上的主要组件之一&#xff0c;它负责管理节点上的容器&#xff0c;并与 Kubernetes 控制平面交互以确保容器在集群中按照期望的方式运行。kubelet 的代码位于 Kubernetes 代码库的 pkg/kubelet 目录下。 pkg/kubelet 目录…

数学建模-分类模型 Fisher线性判别分析

论文中1. 判别分析系数 2. 分类结果 多分类问题 勾选内容和上面一样

【C++】入门 --- 命名空间

文章目录 &#x1f36a;一、前言&#x1f369;1、C简介&#x1f369;2、C关键字 &#x1f36a;二、命名冲突&#x1f36a;三、命名空间&#x1f369;1、命名空间定义&#x1f369;2、命名空间的使用 &#x1f36a;四、C输入&输出 &#x1f36a;一、前言 本篇文章是《C 初阶…

Linux笔记——管道相关命令以及shell编程

文章目录 管道相关命令 目标 准备工作 1 cut 1.1 目标 1.2 路径 1.3 实现 2 sort 2.1 目标 2.2 路径 2.3 实现 第一步: 对字符串排序 第二步&#xff1a;去重排序 第三步: 对数值排序 默认按照字符串排序 升序 -n 倒序 -r 第四步: 对成绩排序【按照列排序】 …

ffmpeg中filter_query_formats函数解析

ffmpeg中filter_query_formats主要起一个pix fmt引用指定的功能。 下下结论&#xff1a; 先看几个结构体定义&#xff1a; //删除了一些与本次分析不必要的成员 struct AVFilterLink {AVFilterContext *src; ///< source filterAVFilterPad *srcpad; ///<…

PhpStudy靶场首页管理

PhpStudy靶场首页管理 一、源码一二、源码二三、源码三四、源码四 一、源码一 index.html <!DOCTYPE html> <html><head><meta charset"UTF-8"><title>靶场访问首页</title><style>body {background-color: #f2f2f2;colo…

JavaDemo——使用jks的https

java使用https主要就是设置下sslContext&#xff0c;sslContext初始化需要密钥管理器和信任管理器&#xff0c;密钥管理器用于管理本地证书和私钥&#xff0c;信任管理器用于验证远程服务器的证书&#xff0c;这两种管理器都需要KeyStore初始化&#xff0c;两种管理器可以按需只…

Ubuntu 网络配置指导手册

一、前言 从Ubuntu 17.10 Artful开始&#xff0c;Netplan取代ifupdown成为默认的配置实用程序&#xff0c;网络管理改成 netplan 方式处理&#xff0c;不在再采用从/etc/network/interfaces 里固定 IP 的配置 &#xff0c;配置写在 /etc/netplan/01-network-manager-all.yaml 或…