Python列表增删改查

在列表末尾添加一个元素:
列表.append() 方法会在列表末尾新增一个元素,
在列表中间某个位置插入一个元素
在列表中间某个位置插入一个元素”,要清楚到底是“哪个位置”,以及“什么元素”。这正是 insert() 方法要求的两个参数的意义——插入的位置(索引值),以及新元素内容。
students.insert(9, '贾琏')。

列表元素的删除

  • pop() 的功能是:返回列表指定位置的元素,并删除这个元素。 pop() 可以传入一个索引,表示要删除的元素的索引,如果不传入,就默认为最后一个元素的索引。
students = [ '林黛玉', '薛宝钗', '贾元春', '贾探春', '史湘云',  '妙玉', '贾迎春', 
'贾惜春', '王熙凤',  '贾琏', '贾巧姐', '李纨', '秦可卿', '贾宝玉']
students.pop()
# 下面来验证操作过后的名单
print(len(students))  # len() 函数用于获取序列的元素个数
# 输出:13

以上的代码中,第一行 pop() 括号内也可以填上宝玉的索引,写成 students.pop(13),这两种写法是等价的,都会将宝玉从列表中移除,而 students 的名单上变为 13 个人。
大家可能觉得 pop() 方法的功能有点复杂,一时难以理解。我们就来聊聊 pop() 方法的由来。

“pop”作为英文单词,除了我们熟悉的“流行”的意思,还能表示“气泡冒出水面”。我们想象一下水中的气泡冒出水面的样子:气泡一个个离开水下的位置,冒到水面让大家看到。

pop() 方法,就像一个比喻,把列表中的元素比做水里的一个个气泡,离开水中就是从列表中删除元素,冒出“水面”就是将删除的值返回,这样我们就能把它打印到屏幕上啦。

当然,我们可以定义一个变量来捕获这个冒出的“气泡”,进行下一步操作。比如,你不想光打印出宝玉的名字,还要加工成完整的语句通知大家。这时候就可以定义变量 punished ,用来捕获 pop() 方法返回并删除的元素后再进行操作。下面我们重新来操作惩罚宝玉前的 14 人花名册:

punished = students.pop()
print('被罚站的人是:' + punished + ',同学们引以为戒。')
# 输出:被罚站的人是:贾宝玉,同学们引以为戒。

del 列表[索引] 意思就是“删除列表中指定索引的元素”。这里正向和反向索引都是支持的。

# 黛玉索引为 0 (删除黛玉)
del students[0]

# 验证一下是否成功
print(len(students))
# 输出:12

通过 列表.remove(值) 的方式,我们可以在列表中找到 第一个 指定的值,然后将它删除。

students.remove('王熙凤')#(按照值删除)

# 验证一下是否成功
print(len(students))
# 输出:11

分片

列表分片用一对以冒号分隔的索引位置表示,格式为 列表[起始索引:结束索引]。比如要获取 students 中第三到第五个元素,也就是索引为 2,3,4 的元素,就要写成 students[2:5]。
要特别注意,不是 students[2:4]!在这里很多同学会迷惑,老师为什么要多此一举,把范围末尾的元素索引往后挪一位呢?
Python 语言在此如此设计,其实是考虑到我们日常数数的一个漏洞,所以有意而为之。
问大家一个问题:从 77 数到到 85,一共要数多少个数字?
有的同学可能会直接两数相减,85 - 77 = 8,所以是 8 个数!
真的吗?仔细数数,其实正确算法是 85 - 77 + 1 = 9。
列表的分片,为了方便我们一眼看出这段范围的长度,主动将结束索引向后挪了一位。这样,students[2:5] 就能明确告诉我们,这段范围包含了 5 - 2 = 3 个元素。如果写成 students[2:4],就很不方便我们直接算出范围长度了。

列表的其他操作:

统计元素出现的次数

count() 方法可以统计元素在列表中出现的次数,使用起来很简单:

students = ['林黛玉', '贾宝玉', '薛宝钗', '贾宝玉']
print(students.count('贾宝玉'))
# 输出:2

排序

sort() 是一个很强大的方法,可以对列表内的元素进行排序,直接调用 students.sort() 后,Python 会使用默认的排序方法对其排序。不同数据类型的排序方法不一样,我们来看看对字符串列表和数值列表进行排序的不同:

str_list = ["lin", "jia", "xue"]
str_list.sort()
print(str_list)
# 输出:['jia', 'lin', 'xue']

num_list = [4, 2, 1, 9]
num_list.sort()
print(num_list)
# 输出:[1, 2, 4, 9]

字符串列表的排序按照每个元素首字母的顺序来排序,比如 j 在 l 前面,l 在 x 前面,可以简单地按照 26 个字母顺序表即可;
数值列表的排序是按照数值大小从小到大进行排序,比如 1 比 2 小,所以 1 在 2 前面。

反转、复制和清空

剩下的 reverse()、copy()、clear() 方法比较简单:

# reverse() 方法:将列表顺序反转
students = ["林黛玉", "贾宝玉", "薛宝钗"]
students.reverse()
print(students)
# 输出:['薛宝钗', '贾宝玉', '林黛玉']

# copy() 方法:复制一个同样的列表
students1 = ["林黛玉", "贾宝玉", "薛宝钗"]
students2 = students1.copy()
print(students2)
# 输出:['林黛玉', '贾宝玉', '薛宝钗']

# clear() 方法:清空列表
students = ["林黛玉", "贾宝玉", "薛宝钗"]
students.clear()
print(students)
# 输出:[]

reverse() 方法在需要倒序输出列表内容时很实用。而 copy() 和 clear() 方法你可能比较困惑,直接将 students2 = students1 不就复制了同样的列表,直接 students = [] 不就清空了列表了吗?为什么还要 copy() 和 clear() 方法。我直接用代码给你解释吧!

students1 = ["林黛玉", "贾宝玉", "薛宝钗"]
students2 = students1
students1[0] = '袭人'
print(students2)
# 输出:['袭人', '贾宝玉', '薛宝钗']

可以看到,我们明明只改了列表 students1 的元素,students2 却也跟着变了!所以,我们可以知道,students2 = students1 并不是复制一个列表,而是给原先的列表一个新的称号 students2。
因此,students1 和 students2 只是同一个列表的不同代号,修改 student1 就是修改 student2,而 copy() 方法不同之处在于,它会新建一个 students2 的列表,里面放着和 students1 一样的内容,彼此互不干扰。

clear() 方法也是类似的,直接使用 students = [] 并不是将原来的列表清空,而是将“students”这个名称冠到一个新建的空列表上,而原来的列表失去了自己的代号。clear() 方法是直接对原来的那个列表进行操作。

你可能感兴趣的:(Python列表增删改查)