百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 热门文章 > 正文

python之列表知识点总结

bigegpt 2025-01-03 14:20 52 浏览

列表的定义

列表是最常用的Python数据类型,列表是可变对象,可以存放0至多个元素(即列表的成员,也是对象)。列表是一个有序的序列,序列中的每个元素都分配一个索引,第一个索引是0,第二个索引是1,依此类推。列表的元素可以插入、增加、删除、修改。常见的操作有索引,切片,加,乘,检查成员等。python已经内置确定列表长度以及确定列表元素最大值、最小值的方法。

列表的创建

  • 空列表,一对圆括号。
t=[]
print(type(t))

out:
<class 'list'>
  • 1个元素的列表,用方括号将这个元素包围。
t = [1]
print(type(t))

out:
<class 'list'>
  • 多个元素的列表,用方括号将多个元素包围,同时元素之间用逗号隔开。
t=[1,2,3]
print(type(t))

out:
<class 'list'>
  • 其他类型转换成列表。
tuple1 = (1, 2, 3)
set1 = {1, 2, 3}
dict1 = {1: 'a', 2: 'b', 3: 'c'}
list1 = list(tuple1)
list2 = list(set1)
list3 = list(dict1)
print(list1, type(list1))
print(list2, type(list2))
print(list3, type(list3))

out:
[1, 2, 3] <class 'list'>
[1, 2, 3] <class 'list'>
[1, 2, 3] <class 'list'>
  • 列表推导式。
list1 = [i for i in range(10)]
list2 = [i for i in range(10) if i % 2 == 0]
list3 = [i + j * 2 for i in range(3) for j in range(3)]
list4 = [
    (i, j, k)
    for i in range(1,3)
    for j in range(1,3)
    for k in range(1,3)
    if i == j
]
print(list1, type(list1))
print(list2, type(list2))
print(list3, type(list3))
print(list4, type(list4))

out:
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9] <class 'list'>
[0, 2, 4, 6, 8] <class 'list'>
[0, 2, 4, 1, 3, 5, 2, 4, 6] <class 'list'>
[(1, 1, 1), (1, 1, 2), (2, 2, 1), (2, 2, 2)] <class 'list'>

列表的增加与运算

  • 列表是可变对象,可以在队尾增加元素,效率极高。也可以插入元素,但插入效率很低,因为插入时会产生大量移动操作,除非必要,否则不建议插入元素。
list1 = [1, 2, 3]
print(list1, id(list1))
list1.append(4)
print(list1, id(list1))
list1.extend([5,6])
list1.insert(0,0.5)
list1.insert(3,2.5)
print(list1, id(list1))

out:
[1, 2, 3] 2984233256832
[1, 2, 3, 4] 2984233256832
[0.5, 1, 2, 2.5, 3, 4, 5, 6] 2984233256832
  • 列表有+和*运算,但是不建议这样用,因为*运算实际是新建列表,效率低;+运算虽不是新建列表,但运行速度明显低于c代码的内置append方法,添加元素强烈建议使用append和extend。
list1 = [1, 2, 3]
print(list1, id(list1))
list1 += (4,)
print(list1, id(list1))
list1 = list1 * 2
print(list1, id(list1))

out:
[1, 2, 3] 1367941064832
[1, 2, 3, 4] 1367941064832
[1, 2, 3, 4, 1, 2, 3, 4] 1367941065472

列表的删除

  • del:根据索引值删除元素,也可以直接删除列表本身。
list1 = [i for i in range(5)]
del list1[0]
print(list1)
del list1

out:
[1, 2, 3, 4]
  • pop():根据索引值删除元素,不指定索引则删除队尾元素。pop方法有返回值
list1 = [i for i in range(5)]
print(list1.pop(),list1)
print(list1.pop(0),list1)

out:
4 [0, 1, 2, 3]
0 [1, 2, 3]
  • remove():根据元素值进行删除,在不确定索引只确定值的情况下用这个方法。需要注意的是,remove方法只删除第一个匹配的元素。若列表中不存在该值会引发 ValueError 错误。
list1 = [i for i in range(3)]*2
print(list1)
list1.remove(2)
print(list1)
#  list1.remove(3)    ValueError: list.remove(x): x not in list

out:
[0, 1, 2, 0, 1, 2]
[0, 1, 0, 1, 2]
  • clear():清空列表内容,保留列表本身,在循环体中需要清空列表时优先用这个方法,而不要新建列表,因为新建的开销相对较大。
list1 = [i for i in range(5)]
list1.clear()
print(list1)

out:
[]

列表的修改

  • 列表是可变对象,可以通过下标、切片方法确认修改范围来修改列表的内容。
list1 = [i for i in range(5)]
list1[0] = 'a'
list1[1:3] = 'bc'
print(list1)

out:
['a', 'b', 'c', 3, 4]

列表的查询

  • 列表的查询是in 运算。
list1 = [i for i in range(5)]
print(5 in list1)
print(5 not in list1)
print(1 in list1)

out:
False
True
True

列表的内置方法

列表的内置方法比元组多了不少,除了上面说过的append、extend、instert、remove、pop、clear,还有一些序列通用方法len、index、count、copy,列表专属方法sort、reverse。

  • len,返回列表的元素长度
  • index,查询列表中某元素出现的位置
  • count,统计列表中某元素出现的次数
  • copy,建立列表的副本,内容一致,id不同。(注意:嵌套结构要用deepcopy)

以下是案例

list1 = ['今日', '头条', '关于', '列表', '列表', 1, 1]
print(list1.index('列表'))
print(list1.count(1))
print(len(list1))
list2 = list1
list3 = list1.copy
print(id(list1),id(list2),id(list3))
list2 = list1  # 直接等于复制过来的是相同的id
list3 = list1.copy  # copy复制过来的内容相同,但id不同
print(id(list1),id(list2),id(list3))

out:
3
2
7
2270698482048 2270698482048 2270698383456
  • sort,将列表元素排序,语法示范,list.sort( key=None, reverse=False),key可指定索引方法(lambda表达式或自定义方法),reverse指定是否倒序排列。sort直接改动原列表顺序。
  • sorted,和sort基本类似,但不改动原列表顺序,而是返回新列表,要另外定义变量接收排序结果。
  • reverse,将列表元素按索引倒置排列,reverse直接改动原列表的顺序。使用切片方法list[::-1],也可将列表元素按索引倒序排列,但不改动原列表顺序,要另外定义变量接收排序结果。
list1 = [3, 5, 6, 1, 2, 4]
list1.sort()
print(list1)

out:
[1, 2, 3, 4, 5, 6]

list1 = [3, 5, 6, 1, 2, 4]
list2 = sorted(list1)
print(list1)
print(list2)

out:
[3, 5, 6, 1, 2, 4]
[1, 2, 3, 4, 5, 6]
list1 = [3, 5, 6, 1, 2, 4]
list1.reverse()
print(list1)

out:
[4, 2, 1, 6, 5, 3]

列表的元素获取方法(跟元组一样)

  • 解包,用_接收不需要的元素,加*表示这个变量是列表,可以接收多个元素,不加则只能接收一个元素。
t = ['今日', '头条', '关于', '列表', '列表', 1, 1]
# 获取列表t的前2个元素
a, b, *_ = t
print(_, type(_))
print(a, b)
# 获取列表t的最后2个元素
*_, num1, num2 = t
print(num1, num2)
# 获取列表t的倒数第3个元素
*_, ts, _, _ = t
print(ts)

out:
['关于', '列表', '列表', 1, 1] <class 'list'>
今日 头条
1 1
列表
  • 切片,切片谨记2点,一是索引从0开始,二是左开右闭:
t = ['今日', '头条', '关于', '列表', '列表', 1, 1]
# 打印列表t的前2个元素
print(t[:2])
# 倒序打印列表t
print(t[::-1])
# 打印列表的第4、和第5个元素。
print(t[3:5])

out:
['今日', '头条']
[1, 1, '列表', '列表', '关于', '头条', '今日']
['列表', '列表']

列表的嵌套结构(跟元组一样)

t = [(1, 2, 3), (4, 5, 6), (7, 8, 9), [10, 11, 12]]
# 打印6
print(t[1][2])
# 将10改成666,再打印出来
t[3][0] = 666
print(t[3][0])

out:
6
666

相关推荐

ActiveAndroid使用(对象化数据库)

配置模块的build.gradlerepositories{mavenCentral()mavenLocal()maven{url"https://oss.sonatype.org/conte...

AndroidStudio下的依赖管理(android app依赖外部jar包)

在开发中用第三方库是很常见的事,如何在AndroidStudio下管理这些依赖呢?这就是这篇文章的目的。目录Maven/Ivy仓库依赖Module依赖aar文件依赖jar文件依赖例子完整代码一、Mav...

Android Studio之gradle的配置与介绍

1、gradle的简单介绍Gradle是可以用于Android开发的新一代的BuildSystem,也是AndroidStudio默认的build工具。其实Gradle脚本是基于一种JVM语言—...

Android中的run-as命令带来的安全问题

一、前言最近一周比较忙,没时间写东西了,今天继续开始我们今天的话题:run-as命令,在上周的开发中,遇到一个问题,就是在使用run-as命令的时候出现了一个错误,不过当时因为工作进度的问题,这问题就...

Android系统级深入开发——input驱动程序

1、Input驱动程序是Linux输入设备的驱动程序,分成游戏杆(joystick)、鼠标(mouse和mice)和事件设备(Eventqueue)3种驱动程序。其中事件驱动程序是目前通用的驱动程序...

Android项目中如何用好构建神器Gradle?

CSDN移动将持续为您优选移动开发的精华内容,共同探讨移动开发的技术热点话题,涵盖移动应用、开发工具、移动游戏及引擎、智能硬件、物联网等方方面面。如果您想投稿、参与内容翻译工作,或寻求近匠报道,请发送...

Android Studio自定义文件类头(android studio自定义标题栏)

--简书作者谢恩铭转载请注明出处今天给大家介绍一个很简单的"小"技巧。平时,我们在AndroidStudio中开发Android时,总免不了要创建新的文件,也许是Java文件,也许是C...

C语言#include头文件真的是插入代码吗?

若文章对您有帮助,欢迎关注程序员小迷。助您在编程路上越走越好!编译器理论和实作既是又不是。从编译器理论理解,#include头文件"相当于"插入了头文件的代码,以供源代码引用(宏定...

Android 系统核心机制binder(03)binder C++层实现

本章关键点总结&说明:这里主要关注BinderC++部分即可,看到,也是本章节的核心内容,主要就是以C++封装的框架为主来解读binder。之前主要针对于底层驱动binder的数据交互以及...

Java对象序列化与反序列化的那些事

Java对象序列化与反序列化的那些事在Java的世界里,对象序列化和反序列化就像一对孪生兄弟,它们共同构成了Java对象存储和传输的基础。如果你曾经尝试将对象保存到文件中,或者在网络中传输对象,那么你...

Java对象序列化剖析(java 对象序列化)

对象序列化的目的1)希望将Java对象持久化在文件中2)将Java对象用于网络传输实现方式如果希望一个类的对象可以被序列化/反序列化,那该类必须实现java.io.Serializable接口或jav...

C++模板 - 16(SFINAE)(c++模板编程)

C++支持函数重载,同一个函数名,只要它的签名不一样,可以声明若干个版本(这个特性也是必须的,不然构造函数就只能有一个了)。现在函数的重载集合中又加入了新的成员-函数模板,事情就变得越发有趣起来,...

NewtoSoft.Json相关使用技巧(newtosoft.json相关使用技巧有哪些)

  本篇将为大家介绍Newtonsoft.Json的一些高级用法,可以修改很少的代码解决上述问题。Newtonsoft.Json介绍  在做开发的时候,很多数据交换都是以json格式传输的。而使用Js...

C#调用DeepSeek API(c#调用deepseek api 流式输出)

一、官方网站二、DeepSeek测试DeepSeek三大适用模式:基础模型(V3)、深度思考(R1)、联网搜索。基础模型(V3)深度思考(R1)联网搜索三、C#调用DeepSeekAPI核心代码//...

.NET性能系列文章二:Newtonsoft.Json vs System.Text.Json

微软终于追上了?图片来自GlennCarstens-Peters[1]Unsplash[2]欢迎来到.NET性能系列的另一章。这个系列的特点是对.NET世界中许多不同的主题进行研究、基准和比较...