🍎 博客主页:🌙@披星戴月的贾维斯
🍎 欢迎关注:👍点赞🍃收藏🔥留言
🍇系列专栏:🌙 Python专栏
🌙请不要相信胜利就像山坡上的蒲公英一样唾手可得,但是请相信,世界上总有一些美好值得我们全力以赴,哪怕粉身碎骨!🌙
🍉一起加油,去追寻、去成为更好的自己!
文章目录
- 🍎1、列表
- 🍎2、列表的切片操作
- 🍎3、列表元素的遍历
- 🍎4、列表的增删查连
- 🍎5、元组
- 🍎总结
提示:以下是本篇文章正文内容,下面案例可供参考
🍎1、列表
🍇1.1列表的定义
列表是一种让程序猿在代码中批量表示/保存数据的方式。
编程中, 经常需要使用变量, 来保存/表示数据.
如果代码中需要表示的数据个数比较少, 我们直接创建多个变量即可.
比如说:
a = 1
b = 2
c = 3
但是有的时候, 代码中需要表示的数据特别多, 甚至也不知道要表示多少个数据. 这个时候, 就需要用到列表.
比如说:
a = []; # []就代表是列表
注意:元组和列表的区别
元组和列表相比, 是非常相似的, 只是列表中放哪些元素可以修改调整, 元组中放的元素是创建元组的时候就设定好的, 不能修改调整.
🍇1.2列表的创建
- 创建列表主要有两种方式. [ ] 表示一个空的列表.
lista = []
lista = list()
print(type(lista))
- 如果需要往里面设置初始值, 可以直接写在 [ ] 当中。这一点的和数组的使用很像。我们也可以直接打印列表中的值。
lista = [9, 8, 7, 6, 5, 4]
print(lista)
输出:
[9, 8, 7, 6, 5, 4]
- 列表中存放的元素允许是不同的类型. (这一点和 C++ Java 差别较大).
lista = [9,'haha', 'hello', False]
print(lista)
输出
[9, 'haha', 'hello', False]
🍇1.3列表通过下标访问
在列表中,我们可以通过列表的下标去访问对应的元素,这一点和数组或者vector很像, 下标也可以称为索引,下标从0开始。
代码示例:
lista = [9,'haha', 'hello', False, 8, 7, 5, 4]
print(lista[2])
我们不仅能通过下标去访问列表对应元素的位置,我们还可以修改对应下标的值。
代码示例:
lista = [9,'haha', 'hello', False, 8, 7, 5, 4]
lista[2] = 'string'
print(lista)
输出:
[9, 'haha', 'string', False, 8, 7, 5, 4]
注意:
- 我们对列表操作时,不能越界,不然会报错。
- 因为下标是从 0 开始的, 因此下标的有效范围是 [0, 列表长度 - 1]. 使用 len 函数可以获取到列表的元素个数.
- 下标可以取负数. 表示 “倒数第几个元素”
代码示例:
lista = [9,'haha', 'hello', False, 8, 7, 5, 4]
lista[2] = 'string'
print(lista[2])
print(lista[-6])
代码输出:
string
string
解释:因为string是第二个位置,也是倒数第六个位置。
🍎2、列表的切片操作
🍇2.1什么是切片操作
通过下标操作是一次取出里面第一个元素.
通过切片, 则是一次取出一组连续的元素, 相当于得到一个子列表。
- 使用 [ : ] 的方式进行切片操作.
代码示例:
listb = [1, 2, 3, 4, 5, 6, 7, 8, 9 ]
print(listb[2 : 5])
输出:
[3, 4, 5]
解释:因为我们传进去的是一个左闭右开区间就是下标从 [2 - 5)的区间内的3个数。
- 切片操作还可以指定 “步长” , 也就是 “每访问一个元素后, 下标自增几步”
代码示例:
listb = [1, 2, 3, 4, 5, 6, 7, 8, 9 ]
print(listb[::1])
print(listb[::2])
print(listb[::3])
print(listb[::5])
输出:
[1, 2, 3, 4, 5, 6, 7, 8, 9]
[1, 3, 5, 7, 9]
[1, 4, 7]
[1, 6]
- 切片操作指定的步长还可以是负数, 此时是从后往前进行取元素. 表示 "每访问一个元素之后, 下标自减几步。
代码示例:
listb = [1, 2, 3, 4, 5, 6, 7, 8, 9 ]
print(listb[::1])
print(listb[::2])
print(listb[::3])
print(listb[::5])
输出:
[9, 8, 7, 6, 5, 4, 3, 2, 1]
[9, 7, 5, 3, 1]
[9, 6, 3]
[9, 4]
- 如果切片中填写的数字越界了, 不会有负面效果. 只会尽可能的把满足条件的元素输出。
代码示例:
listb = [1, 2, 3, 4, 5, 6, 7, 8, 9 ]
print(listb[50:100])
输出:[]
🍎3、列表元素的遍历
🍇3.1什么是切片操作
“遍历” 指的是把元素一个一个的取出来, 再分别进行处理.
- for循环遍历列表元素
代码示例:
listb = [1, 2, 3, 4, 5, 6, 7, 8, 9,'haha', 'nihao' ]
for elem in listb:
print(elem)
输出:
1
2
3
4
5
6
7
8
9
haha
nihao
- 也可以使用 for 按照范围生成下标, 按下标访问
代码示例:
for i in range(0, len(listb)):
print(listb[i])
- 还可以使用 while 循环. 手动控制下标的变化
代码示例:
listb = [1, 2, 3, 4, 5, 6, 7, 8, 9,'haha', 'nihao' ]
i = 0
while i < len(listb):
print((listb[i]))
i+=1
🍎4、列表的增删查连
🍇4.1新增元素
- 使用 append 方法, 向列表末尾插入一个元素(尾插).
代码示例:
listb = [1, 2, 3, 4, 5, 6, 7, 8, 9,'haha', 'nihao' ]
listb.append('888@qq.com')
print(listb)
输出:
[1, 2, 3, 4, 5, 6, 7, 8, 9, 'haha', 'nihao', '888@qq.com']
- 使用 insert 方法, 向任意位置插入一个元素
代码示例:
listb = [1, 2, 3, 4, 5, 6, 7, 8, 9,'haha', 'nihao' ]
listb.insert(2, '666');
print(listb)
输出:
[1, 2, '666', 3, 4, 5, 6, 7, 8, 9, 'haha', 'nihao']
拓展:什么是 “方法” (method)
方法其实就是函数. 只不过函数是独立存在的, 而方法往往要依附于某个 “对象”.
像上述代码 alist.append , append 就是依附于 listb, 相当于是 “针对 listb 这个列表, 进行尾插操作”.
🍇4.2查找元素
- 使用 in 操作符, 判定元素是否在列表中存在. 返回值是布尔类型
代码示例:
listb = [1, 2, 3, 4, 5, 6, 7, 8, 9,'haha', 'nihao' ]
print(6 in listb)
print('haha' in listb)
print('lala' in listb)
输出:
True
True
False
- 使用 index 方法, 查找元素在列表中的下标. 返回值是一个整数. 如果元素不存在, 则会抛出异常.
代码示例:
listb = [1, 2, 3, 4, 5, 6, 7, 8, 9,'haha', 'nihao' ]
print(listb.index(2))
print(listb.index('haha'))
#print(listb.index('lala'))
输出:
1
9
但是如果查询一个列表中不存在的值,就会抛异常。
🍇4.3删除元素
- 使用 pop 方法删除最末尾元素
代码示例:
listb = [1, 2, 3, 4, 5, 6, 7, 8, 9,'haha', 'nihao']
listb.pop()
listb.pop()
print(listb)
输出:
[1, 2, 3, 4, 5, 6, 7, 8, 9]
- pop 也能按照下标来删除元素
代码示例:
listb = [1, 2, 3, 4, 5, 6, 7, 8, 9,'haha', 'nihao']
listb.pop(2)
listb.pop(4)
print(listb)
输出:
[1, 2, 4, 5, 7, 8, 9, 'haha', 'nihao']
- 使用 remove 方法, 按照值删除元素.
代码示例:
listb = [1, 2, 3, 4, 5, 6, 7, 8, 9,'haha', 'nihao']
listb.remove(2)
listb.remove(1)
print(listb)
输出:
[3, 4, 5, 6, 7, 8, 9, 'haha', 'nihao']
🍇4.4连接列表
- 使用 + 能够把两个列表拼接在一起.
此处的 + 结果会生成一个新的列表. 而不会影响到旧列表的内容.
代码示例:
listb = [1, 2, 3, 4, 5, 6, 7, 8, 9,'haha', 'nihao']
lista = ['a', 'b','c','d', 'e']
print(lista + listb)
输出:
['a', 'b', 'c', 'd', 'e', 1, 2, 3, 4, 5, 6, 7, 8, 9, 'haha', 'nihao']
- 使用 extend 方法, 相当于把一个列表拼接到另一个列表的后面.
a.extend(b) , 是把 b 中的内容拼接到 a 的末尾. 不会修改 b, 但是会修改 a.
代码示例:
listb = [1, 2, 3, 4, 5, 6, 7, 8, 9,'haha', 'nihao']
lista = ['a', 'b','c','d', 'e']
lista.extend(listb)
print(lista)
print(listb)
输出:
['a', 'b', 'c', 'd', 'e', 1, 2, 3, 4, 5, 6, 7, 8, 9, 'haha', 'nihao']
[1, 2, 3, 4, 5, 6, 7, 8, 9, 'haha', 'nihao']
🍎5、元组
元组的功能和列表相比, 基本是一致的.
元组使用 ( ) 来表示.
tuplea = ()
tuplea = tuple()
元组不能修改里面的元素, 列表则可以修改里面的元素
因此, 像读操作,比如访问下标, 切片, 遍历, in, index, + 等, 元组也是一样支持的.
但是, 像写操作, 比如修改元素, 新增元素, 删除元素, extend 等, 元组则不能支持.
另外, 元组在 Python 中很多时候是默认的集合类型. 例如, 当一个函数返回多个值的时候.
代码示例:
def func():
return 1, 2
ans = func()
print(type(ans))
输出:
<class 'tuple'>
既然已经有了列表, 为啥还需要有元组?
元组相比于列表来说, 优势有两方面:
你有一个列表, 现在需要调用一个函数进行一些处理. 但是你有不是特别确认这个函数是否会把你的列表数据弄乱. 那么这时候传一个元组就安全很多.
字典是一个键值对结构. 要求字典的键必须是 “可hash对象” (字典本质上也是一个hash表). 而一个可hash对象的前提就是不可变. 因此元组可以作为字典的键, 但是列表不行.
🍎总结
- 列表和元组都是日常开发最常用到的类型. 最核心的操作就是根据 [ ] 来按下标操作.
- 在需要表示一个 “序列” 的场景下, 就可以考虑使用列表和元组.
- 如果元素不需要改变, 则优先考虑元组.
- 如果元素需要改变, 则优先考虑列表
本文总结了列表和元组的知识,希望对大家能够有所帮助,感谢支持!