列表

1.序列

  • 基本概念: 序列是Python中最基本的一种数据结构。序列用于保存一组有序的数据,所有的数据在序列当中都有一个唯一的位置(索引)并且序列中的数据会按照添加的顺序来分配索引;数据结构指计算机中数据存储的方式。
  • 序列的分类:可变序列(序列中的元素可以改变):例如 列表(list);不可变序列(序列中的元素不能改变):例如 字符串(str)元组(tuple)
  • 列表:列表是Python中的一个对象
  • 列表的作用:列表中可以保存多个有序的数据;列表是用来存储对象的对象
  • 列表的创建:通过[]来创建一个空列表
list = [1, 2, 3]
print(list)

切片

  • 切片是指从现有列表中获得一个子列表
  • 通过切片来获取指定的元素
  • 语法: 列表[起始 : 结束 : 步长]
  • 通过切片获取元素时,会包括起始位置的元素,不会包括结束位置的元素
  • 起始位置和结束位置的索引可以不写;如果省略结束位置, 则会从当前的开始位置一直截取到最后;如果省略开始位置, 则会从第一个元素截取到结束的元素,但是不包括结束的元素;如果开始位置和结束位置都省略, 则则会从第一个元素开始截取到最后一个元素。
  • 步长表示每次获取元素的间隔,默认是1(可以省略不写)
  • 步长不能是0,但可以是是负数
list = [1, 2, 3, 3, 4, 5, 6, 7, 8, 9, 0]
list1 = list[1:6:2]
print(list1)

通用操作

+和*:+ 可以将两个列表拼接成一个列表;* 可以将列表重复指定的次数 (注意2个列表不能够做乘法,要和整数做乘法运算)

list = [1, 2, 3, 3, 4, 5, 6, 7, 8, 9, 0]
list1 = [11, 12, 13]
list3 = list1+list
print(list3)
list = [1, 2, 3, 3, 4, 5, 6, 7, 8, 9, 0]
list3 = list*2
print(list3)
  • in和not in:in用来检查指定元素是否在列表当中;not in 用来检查指定元素是否不在列表当中
list = [1, 2, 3, 3, 4, 5, 6, 7, 8, 9, 0]

print(4 in list)
  • len() 获取列表中元素的个数
list = [1, 2, 3, 3, 4, 5, 6, 7, 8, 9, 0]

print(len(list))
  • max() 获取列表中最大值
list = [1, 2, 3, 3, 4, 5, 6, 7, 8, 9, 0]

print(max(list))
  • min() 获取列表中最小值
list = [1, 2, 3, 3, 4, 5, 6, 7, 8, 9, 0]

print(min(list))
  • list.index(x[, start[, end]]):第一个参数 获取指定元素在列表中的位置;第二个参数 表示查找的起始位置;第三个参数 表示查找的结束位置
list = [1, 2, 3, 3, 4, 5, 6, 7, 8, 9, 0]

print(list.index(4))
  • list.count(x) 统计指定元素在列表中出现的个数
list = [1, 2, 3, 3, 4, 5, 6, 7, 8, 9, 0]

print(list.count(3))

列表的方法

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

作业

  • 现在有 a = [1,2,3,4,5,6] 用多种方式实现列表的反转([6,5,4,3,2,1]) 并写出推导过程
#第一种方法:翻转列表
list = [1, 2, 3, 4, 5, 6]
list.reverse()
print(list)
#第二种方法:切片
list = [1, 2, 3, 4, 5, 6]
list_1 = list[::-1]
print(list_1)
#第三种方法:列表排序
list = [1, 2, 3, 4, 5, 6]
list.sort(reverse=True)
print(list)
  • 给 用户9次机会 猜1 - 10 个数字随机来猜数字。如果随机的数字和用户输入的数字一致则表示正确,如果不一致则表示错误。最终结果要求用户怎么也猜不对
list = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
for i in range(0, 9):
    num = int(input('请输入1-10中任意一个数字来猜奖'))
    list.append(num)
    print('很遗憾您未能猜中')
    list.remove(num)
print('中奖的数字为:', list[0])


  • 有两个列表 lst1 = [11, 22, 33] lst2 = [22, 33, 44]获取内容相同的元素
list1 = [11, 22, 33]
list2 = [22, 33, 44]
for i in list1:
    if i in list2:
        print(i)

现在有8位老师,3个办公室,要求将8位老师随机的分配到三个办公室中

import random
teachers = [1, 2, 3, 4, 5, 6, 7, 8]

F_room = []
S_room = []
T_room = []
for i in range (8):
    m = random.randint(0, len(teachers) - 1)
    random.choice([F_room, S_room, T_room]).append(teachers[m])
    teachers.remove(teachers[m])
print(f'第一个教室里面有:{F_room},第二个教室里有:{S_room},第三个教室里有:{T_room}')
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值