Dsh006 python基础编程--列表

本文介绍了Python中的序列和列表,详细阐述了序列的基本概念、分类,重点讲解了列表的创建、使用、切片操作、通用操作、修改方法以及遍历方式。此外,还提供了几个列表相关练习,涉及列表的反转、元素查找、删除、插入等操作。
摘要由CSDN通过智能技术生成

1、序列(sequence)

1.1 基本概念

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

1.2 序列的分类

  • 可变序列(序列中的元素可以改变):例如 列表(list)字典(dict)
  • 不可变序列(序列中的元素不能改变):例如 字符串(str)元组(tuple)整数

2、列表(list)

  • 列表是Python中的⼀个对象
  • 列表的作⽤
    • 列表中可以保存多个有序的数据
    • 列表是⽤来存储对象的对象

2.1 列表的使用

  • 列表的创建:通过[]来创建⼀个空列表
  • 列表里存储的数据称之为元素
  • 列表可以保持任意的对象
  • 列表中可以通过索引(index)或者下标来获取列表中的元素
  • 索引从0开始,列表的第一个位置的索引就是0,依此类推

2.2 切片

  • 切⽚是指从现有列表中获得⼀个⼦列表
  • 通过切⽚来获取指定的元素
  • 语法: 列表[起始 : 结束 : 步⻓]
  • 通过切⽚获取元素时,会包括起始位置的元素,不会包括结束位置的元素
  • 做切片操作时,总会返回一个新的列表,不会影响原来的列表
  • 起始位置和结束位置的索引可以不写
    • 如果省略结束位置, 则会从当前的开始位置⼀直截取到最后
    • 如果省略开始位置, 则会从第⼀个元素截取到结束的元素,但是不包括结束的元素
    • 如果开始位置和结束位置都省略, 则则会从第⼀个元素开始截取到最后⼀个元素
  • 步⻓表示每次获取元素的间隔,默认是1(可以省略不写)
  • 步⻓不能是0,但可以是是负数
lst = [12,23,34,45,67]
print(lst[1])            # 输出结果为:23
print(len(lst))          # 输出结果为:5
print(lst[-1])           # 输出结果为:67
print(lst[::-1])         # 输出结果为:[67,45,34,23,12]
print(lst.index(23))     # 输出结果为:1
print(lst[02])         # 输出结果为:[12,23]

3、通用操作(字符串也适用)

  • +和 *
  • +可以将两个列表拼接成⼀个列表
  • *可以将列表重复指定的次数 (注意2个列表不能够做乘法,要和整数做乘
    法运算)
lst = [1,2,3] + [4,5,6]
print(lst)         # 输出结果为:[1,2,3,4,5,6]
lst = [1,2,3] *2
print(lst)         # 输出结果为:[1,2,3,1,2,3]
  • in 和 not in
    • in⽤来检查指定元素是否在列表当中
    • not in ⽤来检查指定元素是否不在列表当中
  • len() 获取列表中元素的个数
  • max() 获取列表中最⼤值
  • min() 获取列表中最⼩值
  • list.index(x[, start[, end]])
    • 第⼀个参数 获取指定元素在列表中的位置,当元素不唯一时默认找前面的元素
    • 第⼆个参数 表示查找的起始位置
    • 第三个参数 表示查找的结束位置
hero = ['孙悟空','猪八戒','沙悟净','小白龙','二郎神','哪吒','小白龙','托塔李天王']
print(hero.index('猪八戒'))       # 输出结果为:1
print(hero.index('小白龙',4,7))   # 输出结果为:6
  • list.count(x) 统计指定元素在列表中出现的个数
hero = ['孙悟空','猪八戒','沙悟净','小白龙','二郎神','哪吒','小白龙','托塔李天王']
print(hero.count('小白龙'))      # 输出结果为:2

4、修改列表

  • 通过切⽚来修改(起始就是给切⽚的内容重新赋值,但是赋值的内容必须是⼀个序列
  • 当设置了步⻓时,序列中元素的个数必须和切⽚中元素的个数保持一致
  • 通过切片来删除元素
    • del list[起始 : 结束]
    • list = []
  • 如果替换的元素大于原有的元素,多余的元素会往后顺延
hero = ['孙悟空','猪八戒','沙悟净','小白龙','二郎神','哪吒','小白龙','托塔李天王']
hero[3] = '九头虫'
print(hero) # 输出结果为:['孙悟空', '猪八戒', '沙悟净', '九头虫', '二郎神', '哪吒', '小白龙', '托塔李天王']
hero = ['孙悟空','猪八戒','沙悟净','小白龙','二郎神','哪吒','小白龙','托塔李天王']
del hero[3] 
print(hero)   # 输出结果为:['孙悟空', '猪八戒', '沙悟净', '二郎神', '哪吒', '小白龙', '托塔李天王']
hero = ['孙悟空','猪八戒','沙悟净','小白龙','二郎神','哪吒','小白龙','托塔李天王']
hero[0:2] = '赵钱孙李'
print(hero)  # 输出结果为:['赵', '钱', '孙', '李', '沙悟净', '小白龙', '二郎神', '哪吒', '小白龙', '托塔李天王']
hero = ['孙悟空','猪八戒','沙悟净','小白龙','二郎神','哪吒','小白龙','托塔李天王']
hero[::2] = '赵钱孙李'
print(hero)   # 输出结果为:['赵', '猪八戒', '钱', '小白龙', '孙', '哪吒', '李', '托塔李天王']
hero = ['孙悟空','猪八戒','沙悟净','小白龙','二郎神','哪吒','小白龙','托塔李天王']
hero[1:3] = []
print(hero)    # 输出结果为:['孙悟空', '小白龙', '二郎神', '哪吒', '小白龙', '托塔李天王']

5、列表的方法

  • append() 向列表的最后添加⼀个元素
hero = ['吕洞宾','何仙姑','韩湘子','蓝采和']
hero.append('张果老')
print(hero)    # 输出结果为:['吕洞宾', '何仙姑', '韩湘子', '蓝采和', '张果老']
  • insert(arg1,arg2) 向列表指定位置插⼊⼀个元素 参数1:要插⼊的位置 参数2:要插⼊的元素
hero = ['吕洞宾','何仙姑','韩湘子','蓝采和']
hero.insert(2,'曹国舅')
print(hero)    # 输出结果为:['吕洞宾', '何仙姑', '曹国舅', '韩湘子', '蓝采和']
  • extend(iterable) 使⽤⼀个新的序列来扩展当前序列(它会将该序列的中元素添加到列表中) 参数需要传递⼀个序列,可以是列表,也可以是字符串;类似于运算符+=
hero = ['吕洞宾','何仙姑','韩湘子','蓝采和']
hero.extend(['铁拐李','汉钟离'])
print(hero)    # 输出结果为:['吕洞宾', '何仙姑', '韩湘子', '蓝采和', '铁拐李', '汉钟离']
hero = ['吕洞宾','何仙姑','韩湘子','蓝采和']
hero.extend('老子')
print(hero)    # 输出结果为:['吕洞宾', '何仙姑', '韩湘子', '蓝采和', '老', '子']
hero = ['吕洞宾','何仙姑','韩湘子','蓝采和']
hero += ['铁拐李','太上老君']
print(hero)    # 输出结果为:['吕洞宾', '何仙姑', '韩湘子', '蓝采和', '铁拐李', '太上老君']
  • clear() 清空序列
hero = ['吕洞宾','何仙姑','韩湘子','蓝采和']
hero.clear()
print(hero)    # 输出结果为:[]
  • pop() 根据索引删除并返回指定元素
hero = ['吕洞宾','何仙姑','韩湘子','蓝采和']
result = hero.pop(2)
print(result)       # 输出结果为:韩湘子
print(hero)         # 输出结果为:['吕洞宾', '何仙姑', '蓝采和']
  • remove() 删除指定元素 (如果相同值的元素有多个,只会删除第⼀个)
hero = ['吕洞宾','何仙姑','韩湘子','蓝采和','何仙姑']
result = hero.remove('何仙姑')
print(hero)       # 输出结果为:['吕洞宾', '韩湘子', '蓝采和', '何仙姑']
  • reverse() 翻转列表
hero = ['吕洞宾','何仙姑','韩湘子','蓝采和']
hero.reverse()
print(hero)     # 输出结果为:['蓝采和', '韩湘子', '何仙姑', '吕洞宾']
  • sort(key=None,reverse=False) ⽤来对列表中的元素进⾏排序 ,默认是升序,reverse:True反序;False 正序
lst = list('adfkjlg')
lst.sort()
print(lst)    # 输出结果为:['a', 'd', 'f', 'g', 'j', 'k', 'l']
lst.sort(reverse = True)
print(lst)    # 输出结果为:['l', 'k', 'j', 'g', 'f', 'd', 'a']

6、遍历列表

6.1 for循环

  • 通过for循环来遍历列表
  • 注意:for循环的代码块会执⾏多次,序列中有⼏个元素就会执⾏⼏次。每执⾏⼀次就会将序列中的⼀个元素赋值给变量,所以我们可以通过变量来获取列表中的元素
h = 0
while h < len(hero):
    print(hero[h])    # 输出结果为:孙悟空 猪八戒 沙悟净 小白龙 二郎神 哪吒
    h += 1
hero = ['孙悟空','猪八戒','沙悟净','小白龙','二郎神','哪吒']
for h in hero:
    print(h)      # 输出结果同上

6.2 range(start,stop[,step])

range()函数,可以生成一个自然数序列
参数说明

  • 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)
hero = ['孙悟空','猪八戒','沙悟净','小白龙','二郎神','哪吒']
for h in range(6):
    print(hero[h])    # 输出结果同上

7、练习

练习1

现在有 a = [1,2,3,4,5,6] 不通过函数的形式实现列表的反转[6,5,4,3,2,1]并写出推导过程

a = [1,2,3,4,5,6] 
print(a[::-1])

练习2

给⽤户9次机会 猜1 - 10 个数字随机来猜数字。如果随机的数字和⽤户 输⼊的数字⼀致则表示正确,如果不⼀致则表示错误。最终结果要求⽤户 怎么也猜不对

借鉴方法1

lst = [1,2,3,4,5,6,7,8,9,10]
for i in range(len(lst)-1):
    num = int(input('请输入一个数字:'))
    print('对不起,输入错误!')
    for k in range(len(lst)-1):
        if num == lst[k]:
            del lst[k]
print('正确的数字是:',lst[0])

借鉴方法2

lst = [1,2,3,4,5,6,7,8,9,10]
num = int(input('请输入一个数字:'))
lst.remove(num)
i = 0
while i < 8:
    i += 1
    num2 = int(input('答案有误,继续输入:'))
    lst.remove(num2)
else:
    print('正确数字是:',lst[0])

借鉴方法3

import random    # 随机数模块
lst = []
i = 0
while i < 9:
    num = int(input('请输入一个数字:'))
    lst.append(num)   #将用户猜过的数字添加到列表中
    print('对不起,猜错了!')
    i += 1
while True:
    num_x = random.randint(1,10)
    # 判断
    if num_x in lst:
        continue    # 跳过循环,继续随机
    else:
        break       # 退出循环,输出结果
print('正确数字是:',num_x)

练习3

有两个列表 lst1 = [11, 22, 33] lst2 = [22, 33, 44]获取内容相同的元素

lst1 = [11, 22, 33]
lst2 = [22, 33, 44]
for l1 in lst1:
    for l2 in lst2:
        if l1 == l2:
            print(l1)    # 输出结果:22  33
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值