• 小白学 Python(10):基础数据结构(列表)(下)


    人生苦短,我选Python

    前文传送门

    小白学 Python(1):开篇

    小白学 Python(2):基础数据类型(上)

    小白学 Python(3):基础数据类型(下)

    小白学 Python(4):变量基础操作

    小白学 Python(5):基础运算符(上)

    小白学 Python(6):基础运算符(下)

    小白学 Python(7):基础流程控制(上)

    小白学 Python(8):基础流程控制(下)

    小白学 Python(9):基础数据结构(列表)(上)

    列表切片

    一说到列表切片不知道各位同学有没有想起来前面我们讲过的字符串切片,没想起来的同学为自己的记忆默哀 3 秒钟吧。

    开个玩笑:)可以返回去看看之前的文章。

    列表切片是指将列表其中的一部分切出来。

    语法: list[起始索引:终止索引:步长间隔]

    注意: 这里的终止索引和字符串切片是一样的,并不会取到。

    下面直接上代码,解析已经添加在注释中。

    其实我就是懒,不想一条一条拆开写了,来打我呀~

    list1 = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
    
    # 省略步长时默认为 1
    print(list1[3:8])
    # 步长为 2
    print(list1[3:8:2])
    # 从索引 3 开始取到最后
    print(list1[3:])
    # 从头开始取,取到索引 8 ,并且索引 8 娶不到
    print(list1[:8])
    # 取所有,步长为 3
    print(list1[::3])
    # 从索引 1 开始,取到倒数第 2 个,并且倒数第 2 个 取不到
    print(list1[1:-2])
    # 取所有
    print(list1[:])
    # 取逆序列表
    print(list1[::-1])
    # 取逆序,并且步长为 2
    print(list1[8:1:-2])

    执行结果如下:

    [3, 4, 5, 6, 7]
    [3, 5, 7]
    [3, 4, 5, 6, 7, 8, 9]
    [0, 1, 2, 3, 4, 5, 6, 7]
    [0, 3, 6, 9]
    [1, 2, 3, 4, 5, 6, 7]
    [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
    [9, 8, 7, 6, 5, 4, 3, 2, 1, 0]
    [8, 6, 4, 2]

    列表常用方法

    我们这里分别演示一下:

    list.append(obj)

    在列表末尾添加新的对象

    list1.append("Python")
    print(list1)

    结果如下:

    [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 'Python']

    list.count(obj)

    统计某个元素在列表中出现的次数

    list2 = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
    
    list2.append("Python")
    list2.append("Python")
    list2.append("Python")
    list2.append(1)
    print(list2.count("Python"))
    print(list2.count(1))

    结果如下:

    3
    2

    我们这里分别统计了字符串 "Python" 和数字 1 出现的次数。

    list.extend(seq)

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

    list1.extend(list2)
    
    print(list1)

    结果如下:

    [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 'Python', 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 'Python', 'Python', 'Python', 1]

    可以看到 list1 在经过 list2 的扩展后,同时含有了 list1 和 list2 的所有数据。

    extend 和 append 非常像,但是 extend 一次可以添加一个列表,而 append 一次只能添加一个元素。

    list.index(obj)

    从列表中找出某个值第一个匹配项的索引位置

    print(list1.index("Python"))

    结果如下:

    10

    list.insert(index, obj)

    将对象插入列表

    index 是插入的索引值, obj 是要插入的元素。

    list1.insert(0, "Hello")
    print(list1)
    
    list3 = [0, 1, 2]
    list4 = [2, 2]
    list3.insert(1, list4)
    print(list3)

    结果如下:

    ['Hello', 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 'Python', 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 'Python', 'Python', 'Python', 1]
    [0, [2, 2], 1, 2]

    当然插入时可以是一个单独的元素,也可以是一个列表。

    list.pop([index=-1])

    移除列表中的一个元素(默认最后一个元素),并且返回该元素的值

    list3.pop()
    print(list3)
    
    list3.pop(1)
    print(list3)

    结果如下:

    [0, [2, 2], 1]
    [0, 1]

    同样在移除索引的时候,可以移除一个元素,也可以移除一个列表。

    list.remove(obj)

    移除列表中某个值的第一个匹配项

    list5 = [1, 2, 3, 4, 4, 5]
    list5.remove(4)
    print(list5)

    结果如下:

    [1, 2, 3, 4, 5]

    list.reverse()

    反向列表中元素

    list5.reverse()
    print(list5)

    结果如下:

    [5, 4, 3, 2, 1]

    虽然我们刚才用步长为 -1 的形式同样做到了列表逆序,但是这两个操作是不一样的。

    list5 = [1, 2, 3, 4, 4, 5]
    list5.remove(4)
    print(list5)
    print(id(list5))
    list5.reverse()
    print(list5)
    print(id(list5))
    print(id(list5[::-1]))

    结果如下:

    [1, 2, 3, 4, 5]
    2629333420040
    [5, 4, 3, 2, 1]
    2629333420040
    2629333420104

    各位同学看明白了,通过步长获得的逆序列表实际上是一个新的列表,在内存的地址发生了变动,而通过 list.reverse() 打印的逆序列表还是这个列表本身,它的内存地址并未发生改变。

    list.sort( key=None, reverse=False)

    对原列表进行排序

    list6 = [2, 5, 1, 9, 6, 3]
    list6.sort()
    print(list6)
    list6.sort(reverse=True)
    print(list6)

    结果如下:

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

    怎么样,对列表进行正序和逆序排序是不是很简单。

    后面还有两个方法 list.clear() (清空列表) 和 list.copy() (复制列表)我就不做演示,大家可以自己动手尝试一下,有不清楚的可以在公众号后台留言问我。

    示例代码

    本系列的所有代码小编都会放在代码管理仓库 Github 和 Gitee 上,方便大家取用。

    示例代码-Github

    示例代码-Gitee

    转载声明:本博客由极客挖掘机创作,采用 CC BY 3.0 CN 许可协议。可自由转载、引用,但需署名作者且注明文章出处。
  • 相关阅读:
    kettle7.0数据库迁移(MySQL迁移到Postgresql,迁移过程中自动创建表结构)
    正向代理与反向代理区别
    MySQL存储引擎相关知识点
    设计模式-装饰器模式
    设计模式-策略模式
    算法—数据结构学习笔记(二)栈
    Spring Boot2.0学习笔记(一)
    关联容器——map
    迭代器
    C风格字符串
  • 原文地址:https://www.cnblogs.com/alliswell2king/p/11753919.html
Copyright © 2020-2023  润新知