05-python列表&for循环

1. 序列(sequence)

1.1 基本概念

  • 序列是Python中最基本的一种数据结构。序列用于保存一组有序的数据,所有的数据在序列当中都有一个唯一的位置 (索引)并且序列中的数据会按照添加的顺序来分配索引
  • 数据结构指计算机中数据存储的方式

1.2 序列的分类

  • 可变序列(序列中的元素可以改变)例如:
    列表(list) 字典(dict)

  • 不可变序列(序列中的元素不能改变)例如:
    字符串(str) 元组(tuple)

2. 列表(list)

  • 列表是Python中的一个对象
  • 列表的作用:
    1.列表中可以保存多个有序的数据
    2.列表是用来存储对象的对象

2.1 列表的使用

  • 列表的创建:通过 [ ] 来创建一个空列表
    例如:a = [1, 2, 3, 4, 5]

2.2 切片

  • 切片是指从现有列表中获得一个子列表
  • 通过切片来获取指定的元素
  • 通过切片获取元素时,会包括起始位置的元素,不会包括结束位置的元素
  • 起始位置和结束位置的索引可以不写

    1.如果省略结束位置, 则会从当前的开始位置一直截取到最后

    2.如果省略开始位置, 则会从第一个元素截取到结束的元素,但是不包括结束的元素

    3.如果开始位置和结束位置都省略, 则则会从第一个元素开始截取到最后一个元素
  • 步长表示每次获取元素的间隔,默认是1(可以省略不写)
  • 步长不能是0,但可以是是负数
  • 语法: L= [ ]或L = list( )
    L = [1, 2, 3, "a", "b", "c", 1]
    L = list(1, 2, 3, "a", "b", "c", 1)

3. 通用操作

  • +*

    1.+ 可以将两个列表拼接成一个列表
    a = [1, 2, 3]
    b = [4, 5, 6]
    c = a + b
    print(c)

    2.* 可以将列表重复指定的次数 (注意2个列表不能够做乘法,要和整数做乘法运算)

    a = [1, 2, 3] * 2
    print(a)
  • in 和 not in

    1.in用来检查指定元素是否在列表当中
    a = ["red", "blue", "pink"]
    b = "green" in a
    print(b) # 结果返回False

    2.not in 用来检查指定元素是否不在列表当中
    a = ["red", "blue", "pink"]
    b = "green" not in a
    print(b) # 结果返回True
  • len() 获取列表中元素的个数
    a = ["red", "blue", "pink"]
    print(len(a)) # 结果返回3
  • max() 获取列表中最大值
    a = [13121246, 12434125, 21414431]
    print(max(a)) # 结果返回21414431
  • min() 获取列表中最小值
    b = [13121246, 12434125, 21414431]
    print(min(b)) # 结果返回12434125
  • list.index(x[, start[, end]])
    1.第一个参数 获取指定元素在列表中的位置
    2.第二个参数 表示查找的起始位置
    3.第三个参数 表示查找的结束位置
  • list.count(x) 统计指定元素在列表中出现的个数

4. 修改列表

  • 通过切片来修改(起始就是给切片的内容重新赋值,但是赋值的内容必须是一个序列)
  • 当设置了步长时,序列中元素的个数必须和切片中元素的个数保持一致
  • 通过切片来删除元素
    1.del list[起始 : 结束]
    2.list = []
    a = [1, 2, 3, 5, 6, 7, 8, 9, 10]
    del a[4:8]
    print(a) # 结果返回[1, 2, 3, 5, 10]

5. 列表的方法

  • append() 像列表的最后添加一个元素
    a = [1, 2, 3, 4, 5]
    a.append(6)
    print(a) # 结果返回[1, 2, 3, 4, 5, 6]
  • insert(arg1,arg2) 像列表指定位置插入一个元素
    参数1:要插入的位置
    参数2:要插入的元素
    a = [1, 2, 4, 5]
    a.insert(2, 3)
    print(a) # 结果返回[1, 2, 3, 4, 5]
  • extend(iterable) 使用一个新的序列来扩展当前序列(它会将该序列的中元素添加到列表中) 参数需要传递一个序列
    a = [1, 2, 4, 5]
    a.extend([6, 7, 8, 9, 10])
    print(a) # 结果返回[1, 2, 4, 5, 6, 7, 8, 9, 10]
  • pop() 根据索引删除并返回指定元素
    a = [1, 2, 3, 4, 5]
    a.pop(2)
    print(a) # 结果返回[1, 2, 4, 5]
  • remove() 删除指定元素 (如果相同值的元素有多个,只会删除第一个)
    a = [1, 2, 3, 4, 5, 2]
    a.remove(2)
    print(a) # 结果返回[1, 3, 4, 5, 2]
  • reverse() 翻转列表
    a = [1, 2, 3, 4, 5]
    a.reverse()
    print(a) # 结果返回[5, 4, 3, 2, 1]
  • sort(key=None,reverse=False) 用来对列表中的元素进行排序 - reverse:True反序;False 正序

6. 遍历列表

6.1 for循环

  • 通过for循环来遍历列表

语法:

for 变量 in 序列(遍历的规则):
    代码块
  • 注意: for循环的代码块会执行多次,序列中有几个元素就会执行几次。每执行一次就会将序列中的一个元素赋值给变量,所以我们可以通过变量来获取列表中的元素

示例:

browser = ["火狐", "谷歌", "百度", "搜狗", "IE"]
for i in browser:
    print(i)

6.2 range(start, stop[, step])

参数说明

  • ·start: 计数从 start 开始。默认是从 0 开始。例如range(5)等价于range(0, 5);
  • stop: 计数到 stop 结束,但不包括 stop。例如:range(0, 5) 是[0, 1, 2, 3, 4]没有5
  • step:步长,默认为1。例如:range(0, 5) 等价于 range(0, 5, 1)

示例:

number = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
for number in range(1, 10, 2):
    print(number)

在这里插入图片描述

发布了8 篇原创文章 · 获赞 36 · 访问量 3938

猜你喜欢

转载自blog.csdn.net/weixin_46491509/article/details/105679474
今日推荐