百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

python教程从基础到精通,第5课—List列表

off999 2024-12-20 17:57 16 浏览 0 评论

python教程从基础到精通,第5课—List列表

Hello,小伙伴们,又见面啦!

上一章节咱们已学习了七大数据类型的Number(数字)、Boolean(布尔类型)、String(字符串),今天咱们来研究进一步学习List(列表)

1、List(列表)的定义

List的定义方法有很多种,下面以实例来讲,代码如下:

list1 = [] # 创建一个空列表,list1=list(),显示为[]
list2 = [1, 2, 3, 4, 5, 6, 7, 8, 9]
list3 = [
'a', 'b', 'c', 'd', 'e', 'f', 'g']
list4 =
list("abcdefg") # ['a', 'b', 'c', 'd', 'e', 'f', 'g']
list5 = ["abcdefg"] # 只有一个字符串元素
list6 = ['red', 'green', 'blue', 'yellow', 'white', 'black']
list7 = [
1, 2, "hello", 'world'] # 4个元素,前2个为数字,后2个为字符串

是不是很简单,确实。但是如果要创建一个很多的列表呢?有没有更加便捷、高效的定义方法?当然有,我们可以在列表中使用推导式的方法来创建列表,示例代码如下:

lista = [] * 10 # []
listb = [1] * 10 # [1, 1, 1, 1, 1, 1, 1, 1, 1, 1]
listc = [[] for i in range(10)] # [[], [], [], [], [], [], [], [], [], []]
listd = [i for i in range(1, 10)] # [1, 2, 3, 4, 5, 6, 7, 8, 9]
liste = ['1' for i in range(10)] # ['1', '1', '1', '1', '1', '1', '1', '1', '1', '1']
listf = [i * 2 for i in range(10) if i * 2 % 8 == 0] # [0, 8, 16]找出符合条件(i*2%8==0)的值

那么2维或多维列表又如何定义呢?咱们直接看例子:

list1 = [[1, 2, 3], [4, 5, 6], [7, 8, 9]] #定义了一个3行3列的3维列表
list2 = [[1, 2, 3, 4, 5], 'dotcpp', {1, 2, 3, }, ('www', 'dotcpp', 'com')] #定义了一个包含列表、字符串、集合、元组的4维列表
#推导式创建方法如下:

my_list = [[i for i in range(1,7)] for j in range(1,7)]
print(my_list)

如果如下:

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

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

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

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

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

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

2、List(列表)的访问

先来定义一个List,如下:

list 1= ['red', 'green', 'blue', 'yellow', 'white', 'black']

list1总共有6个元素,分别是:'red', 'green', 'blue', 'yellow', 'white', 'black' 6个字符串元素,每个元素都有index索引与value值属性,整个列表有多少个元素可以用len()方法获得。

第1元素的index是0,第2个元素的index是1,以此类推;最后一个元素的index是len(list1)-1,也可以用-1表示,因此倒数第二个元素的索引是-2,其他类推。

要访问列表中的值可以通过索引来实现,例如:

list1 = ['red', 'green', 'blue', 'yellow', 'white', 'black']
print(list1[0]) # red
print(list1[1]) # green
print(list1[5]) # black
print(list1[len(list1)-1]) # black
print(list1[-1]) # black

如果想知道某个元素的索引呢,可以通过以下代码获得:

list1 = ['red', 'green', 'blue', 'yellow', 'white', 'black']

print(list1.index("blue")) # 2

3、List(列表)的切片

List列表切片是非常有用的功能,示例如下:

list1 = ['www', '.', 'test', '.', 'com', '.', 'cn']
print(list1) # ['www', '.', 'test', '.', 'com', '.', 'cn']
print(list1[6]) # 下标是从0开始的,[6]个元素:cn
print(list1[-2]) # 倒数第2个元素:.
print(list1[:3]) # 前3个元素:['www', '.', 'test']
print(list1[3:]) # 第3个元素之后的元素(不包含第3个字符):['.', 'com', '.', 'cn']
print(list1[2:6]) # 第2个元素之后到第6个元素组成的列表:['test', '.', 'com', '.']
print(list1[::2]) # 偶数位置的元素组成的列表:['www', 'test', 'com', 'cn']
print(list1[::-1]) # 逆置列表:['cn', '.', 'com', '.', 'test', '.', 'www']

4、列表的操作方法

1) 改变元素的值

列表的元素是可以改变的,上面讲了可以直接通过索引或下标来访问元素,那么我们可以在访问元素值的时候赋予其新的值,示例代码如下:

list6 = ['red', 'green', 'blue', 'yellow', 'white', 'black']
list6[
0] = "orange"
list6[3] = 'purple'
print(list6) # ['orange', 'green', 'blue', 'purple', 'white', 'black']


2) 增加元素append()、extend()方法

list.append(obj),在列表末尾添加新的对象

list.extend(seq),在列表末尾一次性追加另一个序列中的多个值(用新列表扩展原来的列表)

示例代码:

list1 = ['red', 'green', 'blue']
list2 = [
1, 2, 3]
list1.append(
"grey")
print(list1) #['red', 'green', 'blue', 'grey']
list1.extend(list2)
print(list1) #['red', 'green', 'blue', 'grey', 1, 2, 3]


3) 插入元素insert()方法

list.insert(index,obj),在索引index位置插入对象obj

list2 = [1, 2, 3]

list2.insert(2,[7,8,9]) # 在索引为2的位置插入对象
print(list2) #[1, 2, [7, 8, 9], 3]


4) 删除元素remove()方法、pop()方法

list.remove(obj),移除列表中某个值的第一个匹配项

list.pop([index=-1]),移除列表中的一个元素(默认最后一个元素),并且返回该元素的值

list6 = ['red', 'green', 'blue', 'yellow', 'white', 'black']
list6.remove(
'black')
print(list6) # ['red', 'green', 'blue', 'yellow', 'white']
list6.remove(list6[4])
print(list6) # ['red', 'green', 'blue', 'yellow']
a = list6.pop() # 默认删除最后一个,返回被删除的值
print(list6, a) # ['red', 'green', 'blue'] yellow
list6.pop(1) # 删除下标为1的值
print(list6) # ['red', 'blue']


5) 对列表进行排序sort()方法、reverse()方法

list.sort( key=None, reverse=False),对原列表按ASCII码进行排序,两个参数均可省。

list1 = ['red', 'green', 'blue', 'yellow', 'white', 'black']
list2 = [
'red', 'green', 'blue', 'yellow', 'white', 'black']
list3 = [
'red', 'green', 'blue', 'yellow', 'white', 'black']
list1.sort()
#按字母顺序排序,['black', 'blue', 'green', 'red', 'white', 'yellow']
list2.sort(reverse=True) #按字母逆序排序,['yellow', 'white', 'red', 'green', 'blue', 'black']
list3.sort(key=len) #按长度排序, ['red', 'blue', 'green', 'white', 'black', 'yellow']


基中key可以是做函数,python有内置的函数可以直接用,常用的内置key函数包括:

(1)str.lower() / str.upper():将字符串转换为小写/大写字母后再进行比较。适用于字符串的大小写不敏感的情况。

例如,按照字符串的字母顺序排序:

lst = ['abc', 'A', 'Ab']

lst.sort(key=str.lower)

print(lst)

# 输出:['A', 'Ab', 'abc']

(2)abs():返回数值的绝对值。适用于按照数值大小排序的情况。

例如,按照数值的绝对值大小排序:

lst = [-3, 1, -2]

lst.sort(key=abs)

print(lst)

# 输出:[1, -2, -3]

(3)len():返回对象的长度。适用于按照对象大小排序的情况。

例如,按照字符串长度排序:

lst = ['abc', 'a', 'ab']

lst.sort(key=len)

print(lst)

# 输出:['a', 'ab', 'abc']

list.reverse(),反向列表中元素,代码如下:

list1 = ['red', 'green', 'blue', 'yellow', 'white', 'black']
list1.reverse()
print(list1) # ['black', 'white', 'yellow', 'blue', 'green', 'red']


6) 列表的清空clear()与复制copy()

list1 = ['red', 'green', 'blue']
list2 = [
1, 2, 3]
list2 = list1.copy()
# 列表被新的列表所覆盖
list1.clear() # 清空列表
print(list1) # []
print(list2) # ['red', 'green', 'blue']


7) 列表的的计数方法count()

list.count(obj),统计某个元素在列表中出现的次数

list1 = ['red', 'green', 'blue', 'red']
print(list1.count('blue')) # 1
print(list1.count('red')) # 2

5、其它相关方法或函数

示例代码:

list1 = ['red', 'green', 'blue', 'red']
str1 =
"good boy"
print(len(list1)) # 4
print(max(list1)) # red
print(min(list1)) # blue
print(list(str1)) # ['g', 'o', 'o', 'd', ' ', 'b', 'o', 'y']

愉快学习的时光总是过得很快,一不小心又到结尾啦。

先来给自己一个奖励,双手举起,yeah!

有什么问题可以关注我/私信我/加好友,让我们一起成长吧。


相关推荐

独家 | 5 个Python高级特性让你在不知不觉中成为Python高手

你已经使用Python编程了一段时间,编写脚本并解决各种问题。是你的水平出色吗?你可能只是在不知不觉中利用了Python的高级特性。从闭包(closure)到上下文管理器(contextmana...

Python装饰器

Python装饰器是一种用于修改函数或类的行为的特殊语法。它们允许在不修改原始代码的情况下,通过将函数或类作为参数传递给另一个函数来添加额外的功能。装饰器本质上是一个函数,它接受一个函数作为参数,并返...

中高阶Python常规用法--上下文管理器

Python以简单性和通用性著称,是一种深受全球开发人员喜爱的编程语言。它提供了大量的特性和功能,使编码成为一种愉快的体验。在这些功能中,一个经常被新手忽视的强大工具是上下文管理器。上下文管理器是高...

Python小案例67- 装饰器

Python装饰器是一种用于修改函数或类的行为的特殊语法。它们允许在不修改原始代码的情况下,通过将函数或类作为参数传递给另一个函数来添加额外的功能。装饰器本质上是一个函数,它接受一个函数作为参数,并返...

python常用的语法糖

概念Python的语法糖(SyntacticSugar)是指那些让代码更简洁、更易读的语法特性,它们本质上并不会增加新功能,但能让开发者更高效地编写代码。推导式写法推导式是Python最经典的...

python - 常用的装饰器 decorator 有哪些?

python编程中使用装饰器(decorator)工具,可以使代码更简洁清晰,提高代码的重用性,还可以为代码维护提供方便。对于python初学者来说,根据装饰器(decorator)的字面意思并不...

python数据缓存怎么搞 ?推荐一个三方包供你参考,非常简单好用。

1.数据缓存说明数据缓存可以说也是项目开发中比不可少的一个工具,像我们测试的系统中,你都会见到像Redis一样的数据缓存库。使用缓存数据库的好处不言而喻,那就是效率高,简单数据直接放在缓存中...

用于时间序列数据的Graphite监视工具

结合第三方工具,Graphite为IT性能监控提供了许多好处。本文介绍其核心组件,包括Carbon、Whisper以及安装的基本准则。Graphite监视工具可实时或按需,大规模地绘制来自多个来源的时...

Python3+pygame实现的坦克大战

一、显示效果二、代码1.说明几乎所有pygame游戏,基本都遵循一定的开发流程,大体如下:初始化pygame创建窗口while循环检测以及处理事件(鼠标点击、按键等)更新UI界面2.代码创建一个m...

Python之鸭子类型:一次搞懂with与上下文装饰器

引言在鸭子类型的理念的基础之上,从关注类型,转变到关注特性和行为。结合Python中的魔法函数的体系,我们可以将自定义的类型,像内置类型一样被使用。今天这篇文章中,接着该话题,继续聊一下with语法块...

Python必会的50个代码操作

学习Python时,掌握一些常用的程序操作非常重要。以下是50个Python必会的程序操作,主要包括基础语法、数据结构、函数和文件操作等。1.HelloWorldprint("Hello,...

一文掌握Python 中的同步和异步

同步代码(Sync)同步就像在一个流水线上工作,每个任务都等待前一个任务完成。示例:机器A切割钢板→完成后,机器B钻孔→完成后,机器C上色。在Python中,同步代码看起来像这样:im...

python 标注模块timeit: 测试函数的运行时间

在Python中,可以使用内置的timeit模块来测试函数的运行时间。timeit模块提供了一个简单的接口来测量小段代码的执行时间。以下是使用timeit测试函数运行时间的一般步骤:导入...

Python带你找回童年的万花尺

还记得小时候的万花尺吧?这么画:一点也不费脑筋,就可以出来这么多丰富多彩的复杂几何图形。具体而言,可以用万花尺玩具(如图2-1所示)来绘制数学曲线。这种玩具由两个不同尺寸的塑料齿轮组成,一大一小。小的...

Python 时间模块深度解析:从基础到高级的全面指南

直接上干货一、时间模块核心类介绍序号类名说明1datetime.datetime表示一个具体的日期和时间,结合了日期和时间的信息。2datetime.date表示一个具体的日期。3datetime.t...

取消回复欢迎 发表评论: