美文网首页Python
Python列表增删改查

Python列表增删改查

作者: 陈小云的笔记本 | 来源:发表于2021-03-19 10:40 被阅读0次

    在列表末尾添加一个元素:
    列表.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列表增删改查

        本文链接:https://www.haomeiwen.com/subject/mzkvcltx.html