【Python】列表

【Python】列表

文章目录


前言

本文主要介绍Python中的数据类型——列表的相关概念。


一、列表

列表(list)是一种有序和可更改的集合,列表中允许存在重复元素,允许存在不同类型的元素。

二、创建列表

1. 创建空列表

在python中[]表示一个空列表

a =[]print(type(a))# <class 'list'>print(a)# []

使用list()函数也可以创建一个空列表

a =list()print(type(a))# <class 'list'>print(a)# []

2. 创建非空列表

创建列表时可以设置初始值

a =[1,3,2.2,'Jinger']print(type(a))# <class 'list'>print(a)# [1, 3, 2.2, 'Jinger']

三、操作列表

1. 新增列表元素

1.1 append方法

append方法可以在列表末尾增加一个元素

a =[1,3.0,2.2] a.append('Jinger')print(type(a))# <class 'list'>print(a)# [1, 3.0, 2.2, 'Jinger']

1.2 insert方法

insert方法可以在任意指定下标(支持负索引)插入一个元素

a =[1,3.0,2.2] a.insert(1,'Jinger')print(type(a))# <class 'list'>print(a)# [1, 'Jinger', 3.0, 2.2] a.insert(-1,'Hello')print(type(a))# <class 'list'>print(a)# [1, 'Jinger', 3.0, 'Hello', 2.2]
负索引:
我们常说的下标都是从列表第一个元素开始往后,从0开始计数的,而负索引则是从列表最后一个元素开始往前,依次为-1, -2, -3...
因此想要访问列表的最后一个元素,直接访问下标为-1的元素即可。

注意
如果指定下标超出列表中的最大下标,则插入到列表末尾(如果为负索引,则插入列表首部)

a =[1,3.0,2.2] a.insert(100,'Jinger')print(type(a))# <class 'list'>print(a)# [1, 3.0, 2.2, 'Jinger'] a.insert(-100,'Hello')print(type(a))# <class 'list'>print(a)# ['Hello', 1, 3.0, 2.2, 'Jinger']

2. 删除列表元素

2.1 pop方法

pop方法可以删除列表的末尾元素,或者删除指定下标的元素

a =[1,3.0,2.2] a.pop()print(type(a))# <class 'list'>print(a)# [1, 3.0] a.pop(1)print(type(a))# <class 'list'>print(a)# [1]

2.2 remove方法

remove方法可以删除列表中指定的元素

a =[1,3.0,2.2,3.0] a.remove(3.0)print(type(a))# <class 'list'>print(a)# [1, 2.2, 3.0]

注意
当列表中存在重复元素时,使用remove方法仅能删除第一次出现的元素

3. 查找列表元素

3.1 in/not in操作符

in/not in操作符可以判断某个元素是否在列表中,如果存在则返回True,不存在则返回False

a =[1,3.0,2.2,3.0]print(3in a)# Trueprint(3notin a)# Falseprint(type(a))# <class 'list'>print(a)# [1, 3.0, 2.2, 3.0]

3.2 index方法

index方法可以查询指定元素在列表中的下标

a =[1,3.0,2.2,3.0]print(a.index(2.2))# 2

3.3 下标访问列表元素

通过[]下标访问操作符可以获取到列表中对应下标的元素(支持负索引)

a =[1,3.0,2.2,3.0]print(a[3])# 3.0

4. 修改列表元素

通过[]下标访问操作符还可以修改列表中对应下标的元素的值

a =[1,3.0,2.2,3.0] a[3]=4print(a)# [1, 3.0, 2.2, 4]

5. 遍历列表元素

5.1 for循环遍历列表

Python中的for循环可以直接遍历列表中的元素

a =[1,3.0,2.2,3.0]foriterin a:print(iter)

但是对iter进行更改时,列表中的元素不会受到影响(可以理解为是将列表中对应元素的值赋值给了变量iter,所以修改iter不会影响到列表中的元素)

a =[1,3.0,2.2,3.0]foriterin a:iter+=1print(iter)# 2 4.0 3.2 4.0print(a)# [1, 3.0, 2.2, 3.0]

如果想要通过for循环来修改列表中的元素,可以使用for循环遍历列表元素下标的方式,遍历列表中的元素

a =[1,3.0,2.2,3.0] n =len(a)for i inrange(n): a[i]+=1print(a[i])# 2 4.0 3.2 4.0print(a)# [2, 4.0, 3.2, 4.0]

5.2 while循环遍历列表

while循环也可以通过变量列表元素下标的方式来访问列表元素

a =[1,3.0,2.2,3.0] n =len(a) i =0while i inrange(n):# 或者使用 while i < n a[i]+=1print(a[i])# 2 4.0 3.2 4.0 i +=1print(a)# [2, 4.0, 3.2, 4.0]

6. 子列表提取

6.1 [start:stop]

[start:stop]的方式可以从列表中提取出:从start起始下标开始,到stop结束下标结束的一组元素(左闭右开)

a =[1,3.0,2.2,3.0] b = a[1:2] c = a[0:2] d = a[0:3]print(a)# [1, 3.0, 2.2, 3.0]print(b)# [3.0]print(c)# [1, 3.0]print(d)# [1, 3.0, 2.2]

6.2 切片时忽略边界

提取子列表的过程也称作切片的过程,以[start:stop]的方式进行切片时可以忽略起始下标和结束下标

  • 如果以[start:]的方式进行切片,则子列表的元素包括起始下标的元素及其后续所有元素;
  • 如果以[:stop]的方式进行切片,则子列表的元素包括结束下标之前的所有元素,不包括结束下标的元素
  • 如果以[:]的方式进行切片,则子列表的元素包括原列表的所有元素
a =[1,3.0,2.2,3.0] b = a[1:2] c = a[1:] d = a[:2] e = a[:]print(a)# [1, 3.0, 2.2, 3.0]print(b)# [3.0]print(c)# [3.0, 2.2, 3.0]print(d)# [1, 3.0]print(e)# [1, 3.0, 2.2, 3.0]

注意
切片时所用下标支持负索引

a =[1,3.0,2.2,3.0] b = a[-3:-1]print(a)# [1, 3.0, 2.2, 3.0]print(b)# [3.0, 2.2]

6.3 切片时指定步长

[start:stop:step]的方式切片可以指定step步长(每访问一个元素后下标自增几步),例如

a =[1,3.0,2.2,3.0] b = a[0:3:2]print(a)# [1, 3.0, 2.2, 3.0]print(b)# [1, 2.2]

注意
指定的步长可以为负数,表示从后往前提取元素
当步长为负数时,会从右向左遍历(反向切片),start默认为最后一个元素,stop默认为第一个元素(不包括),只有start大于stop才能切到元素,例如

a =[1,3.1,2.2,3.0] b = a[::-1] c = a[3:0:-1] d = a[-1::-2]print(a)# [1, 3.1, 2.2, 3.0]print(b)# [3.0, 2.2, 3.1, 1]print(c)# [3.0, 2.2, 3.1]print(d)# [3.0, 3.1]

6.4 切片时下标允许越界

如果在切片时,指定的下标超出了有效范围,运行程序不会抛异常,而是会尽可能将符合要求的元素提取出来,例如:

a =[1,3.0,2.2,3.0] b = a[2:100:1] c = a[100:0:-1]print(a)# [1, 3.0, 2.2, 3.0]print(b)# [2.2, 3.0]print(c)# [3.0, 2.2, 3.0]

7. 拼接列表

7.1 使用+拼接两个列表

使用+操作符可以将两个列表拼接起来生成一个新列表,该操作不会影响两个原有列表

a =[1,3.1,2.2,3.0] b =[2.2,'Jinger'] c = a + b print(a)# [1, 3.1, 2.2, 3.0]print(b)# [2.2, 'Jinger']print(type(c))# <class 'list'>print(c)# [1, 3.1, 2.2, 3.0, 2.2, 'Jinger']

7.2 使用+=操作符

使用+=操作符可以将一个列表拼接到另一个列表后面

a =[1,3.1,2.2,3.0] b =[2.2,'Jinger'] b += a print(a)# [1, 3.1, 2.2, 3.0]print(b)# [2.2, 'Jinger', 1, 3.1, 2.2, 3.0]

7.3 extend方法

使用extend方法也可以将一个列表拼接到另一个列表后面

a =[1,3.1,2.2,3.0] b =[2.2,'Jinger'] b.extend(a)print(a)# [1, 3.1, 2.2, 3.0]print(b)# [2.2, 'Jinger', 1, 3.1, 2.2, 3.0]
+=操作符和extend方法都可以将一个列表拼接到另一个列表后面,但是extend方法更高效
因为,b += a等价于b = b + a,拼接过程中会先构造出一个临时列表作为拼接后的列表,再将b原本的列表释放,然后将这个临时列表赋值给b
extend方法则是直接将a列表的元素拼接到b列表后面,避免了不必要的释放操作

四、列表常用接口

Python是一种面向对象的语言,因此创建出来的列表本质是一个对象,这些操作列表的方法都是列表的成员方法。列表的常用接口如下:

1. 列表操作

列表操作方式
子列表提取this_list[start:stop:step]
列表检查innot in
列表拼接++=
列表长度len()函数

2. 列表的成员函数

成员函数功能
copy复制列表
clear清空列表
append在列表末尾添加一个元素
insert在列表指定下标插入一个元素
extend将列表元素(或任意可迭代对象的元素)添加到当前列表的末尾
pop删除列表中指定下标的元素(默认为末尾元素)
remove删除列表中指定元素(首次出现)
index返回列表中指定元素的下标(首次出现)
count返回列表中指定元素的个数
reverse颠倒列表中元素的顺序
sort对列表中元素进行排序

总结

以上就是今天要讲的内容,本文介绍了Python数据类型——列表的相关概念。本文作者目前也是正在学习Python相关的知识,如果文章中的内容有错误或者不严谨的部分,欢迎大家在评论区指出,也欢迎大家在评论区提问、交流。
最后,如果本篇文章对你有所启发的话,希望可以多多支持作者,谢谢大家!

Read more

华为OD机试双机位C卷:自动化维修流水线(C/C++/Java/Python/Go/JS)

华为OD机试双机位C卷:自动化维修流水线(C/C++/Java/Python/Go/JS)

自动化维修流水线 华为OD机试双机位C卷 - 华为OD上机考试双机位C卷 100分题型 华为OD机试双机位C卷真题目录点击查看: 华为OD机试双机位C卷真题题库目录|机考题库 + 算法考点详解 题目描述 小伙伴反馈题目大意:给定m条流水线,流水线可并行处理维修任务,给出n个任务,并给出每个任务的执行时间,要求完成所有任务的最短时间。 输入描述 第一行输入 任务数n和流水线数量m,用空格分割 第二行输入 每个任务完成所用时间 输出描述 输出最短执行完成所有任务数量 用例1 输入 10 1 10 20 30 5 5 5 5 10 5 10 输出 105 题解 思路:二分 + 递归回溯

By Ne0inhk
Python中的鸭子类型:理解动态类型的力量

Python中的鸭子类型:理解动态类型的力量

Python中的鸭子类型:理解动态类型的力量 * 什么是鸭子类型? * 鸭子类型的特点 * 1. 灵活性 * 2. 动态性 * 3. 简洁性 * 鸭子类型的实现 * 鸭子类型的优缺点 * 优点 * 缺点 * 鸭子类型的实际应用 * 1. 插件系统 * 2. 框架开发 * 3. 数据处理 * 总结 Python以其动态类型系统而闻名,而鸭子类型(Duck Typing)是这一系统的核心特性之一。鸭子类型是一种编程范式,它强调“行为”而非“类型”。换句话说,如果一个对象“像鸭子一样行走、游泳和嘎嘎叫”,那么它就可以被视为鸭子,而无需显式地检查其类型。 在这篇博客中,我们将深入探讨鸭子类型的定义、特点、优缺点以及实际应用,帮助你更好地理解和利用这一强大的特性。 什么是鸭子类型? 鸭子类型是一种动态类型机制,其核心思想是:对象的行为决定了它的类型,而不是其声明的类型。在Python中,鸭子类型允许我们在运行时动态地检查对象是否具有所需的方法或属性,

By Ne0inhk
异步编程实战:构建高性能Python网络应用

异步编程实战:构建高性能Python网络应用

目录 摘要 1 异步编程:为什么它是现代网络应用的必然选择 1.1 同步架构的瓶颈与异步架构的优势 2 核心技术原理深度解析 2.1 asyncio事件循环:异步编程的发动机 2.2 aiohttp框架架构解析 3 异步数据库驱动实战 3.1 异步数据库连接池管理 3.2 多数据库支持与连接池优化 4 WebSocket实时通信实战 4.1 构建高性能WebSocket服务器 4.2 实时数据推送与流处理 5 企业级实战案例 5.1 构建异步API网关 6 性能优化与故障排查 6.1 性能优化实战技巧 6.2 常见故障排查指南 7 总结与展望 7.1

By Ne0inhk
Python从0到100(九十五):空洞卷积(Dilated Convolution)网络架构与PAMAP2数据集实验分析

Python从0到100(九十五):空洞卷积(Dilated Convolution)网络架构与PAMAP2数据集实验分析

前言:零基础学Python:Python从0到100最新最全教程。 想做这件事情很久了,这次我更新了自己所写过的所有博客,汇集成了Python从0到100,共一百节课,帮助大家一个月时间里从零基础到学习Python基础语法、Python爬虫、Web开发、 计算机视觉、机器学习、神经网络以及人工智能相关知识,成为学业升学和工作就业的先行者! 【优惠信息】 • 新专栏订阅前500名享9.9元优惠 • 订阅量破500后价格上涨至19.9元 • 订阅本专栏可免费加入粉丝福利群,享受: - 所有问题解答 -专属福利领取 欢迎大家订阅专栏:零基础学Python:Python从0到100最新最全教程! 本文目录: * 一、空洞卷积的基础原理 * 1. 传统卷积的短板 * 2. 空洞卷积的巧妙之处 * 二、空洞卷积的架构 * 1. 输入层 * 2. 空洞卷积模块 * 2.1 空洞卷积层 * 2.2 批归一化和激活 * 3. 整体结构 * 三、代码实现详解

By Ne0inhk