欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

python数据类型_列表(list)使用

程序员文章站 2022-03-27 14:08:32
数据类型_列表序列(sequence)基本概念序列的分类列表(list)列表的使用切片通用操作修改列表(增删改查)增加列表的方法序列(sequence)基本概念• 序列是Python中最基本的一种数据结构。序列用于保存一组有序的数据,所有的数据在序列当中都有一个唯一的位置(索引)并且序列中的数据会按照添加的顺序来分配索引• 数据结构指计算机中数据存储的方式序列的分类• 可变序列(序列中的元素可以改变):例如 列表(list)• 不可变序列(序列中的元素不能改变):例如 字符串(str)元组....

python数据类型_列表(list)使用

序列(sequence)

基本概念

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

序列的分类

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

列表(list)

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

列表的使用

• 列表的创建:通过[]来创建一个空列表

list1=[]

切片

• 切片是指从现有列表中获得一个子列表
• 可通过切片来获取指定的元素
• 语法: 列表[起始 : 结束 : 步长]
• 通过切片获取元素时,会包括起始位置的元素,不会包括结束位置的元素,左开右闭区间

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达"]
	list2=list1[1:4:1]
	print(list2)

•结果:

	['贾玲', '潘斌龙', '周星驰']

• 起始位置和结束位置的索引可以不写

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达"]
	list2=list1[:]
	print(list2)

•结果:

	['沈腾', '贾玲', '潘斌龙', '周星驰', '吴孟达']

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

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达"]
	list2=list1[2:]		#结束位置省略
	print(list2)

•结果:

	['潘斌龙', '周星驰', '吴孟达']

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

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达"]
	list2=list1[:4]		#结束位置省略
	print(list2)

•结果:

	['沈腾', '贾玲', '潘斌龙', '周星驰']

• 如果开始位置和结束位置都省略, 则则会从第一个元素开始截取到最后一个元素

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达"]
	list2=list1[:]
	print(list2)

•结果:

	['沈腾', '贾玲', '潘斌龙', '周星驰', '吴孟达']

• 步长表示每次获取元素的间隔,默认是1(可以省略不写)
• 步长不能是0,但可以是是负数
• 示例1:

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达"]
	list2=list1[1:4:2]
	print(list2)

•结果:

	['贾玲', '周星驰']

• 示例2:

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达"]
	list2=list1[-1:-4:-2]    #从-1-4,步长为-2(从右往左取值)
	print(list2)

•结果:

	['吴孟达', '潘斌龙']

• 示例3:

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达"]
	list2=list1[-1:-4:-2]    #从-1-4,步长为-2(从右往左取值)
	print(list2)

•结果:

	['吴孟达', '潘斌龙']

• 示例4:

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达"]
	list2=list1[-1:-4:1]    #从-1-4,步长为-2(从右往左取值)
	print(list2)

•结果:

	[]	#开始到结束的方向,要与步长方向一致,否则取不到值,产生空列表。

• 示例5:

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达"]
	list2=list1[-1:-4:0]    #从-1-4,步长为-2(从右往左取值)
	print(list2)

•结果:

	ValueError: slice step cannot be zero
	#步长为0.产生错误信息。

通用操作

• + 和*
• + 可以将两个列表拼接成一个列表

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达"]
	list2=["马丽","张小斐","崔志佳","岳云鹏","许君聪"]
	print(list1+list2)

•结果:

	['沈腾', '贾玲', '潘斌龙', '周星驰', '吴孟达', '马丽', '张小斐', '崔志佳', '岳云鹏', '许君聪']

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

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达"]
	list2=["马丽","张小斐","崔志佳","岳云鹏","许君聪"]
	print(list1*list2)

•结果:两个列表不可相乘

	TypeError: can't multiply sequence by non-int of type 'list'

• 示例2:

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达"]
	list2=["马丽","张小斐","崔志佳","岳云鹏","许君聪"]
	print(list1*2)

•结果:

	['沈腾', '贾玲', '潘斌龙', '周星驰', '吴孟达', '沈腾', '贾玲', '潘斌龙', '周星驰', '吴孟达']

• in 和 not in
• in用来检查指定元素是否在列表当中
• not in 用来检查指定元素是否不在列表当中

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达"]
	print("沈腾" in list1)

•结果:

	True
• len() 获取列表中元素的个数
	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达"]
	print(len(list1))

•结果:

	5

• max() 获取列表中最大值
• min() 获取列表中最小值

	list1=[4,2,3,4,5,8,6]
	print('max:',max(list1))
	print('min:',min(list1))

•结果:

	max: 8
	min: 2

• list.index(x[, start[, end]]):获取指定元素在列表中的位置
• 第一个参数 表示需查找的元素
• 第二个参数 表示查找的起始位置
• 第三个参数 表示查找的结束位置
• 示例1:

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达"]
	print(list1.index("沈腾"))

•结果:

	5

• 示例2:

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达"]
	print(list1.index("沈腾",2,4))

•结果:

	ValueError: '沈腾' is not in list         #"沈腾"的位置不在[2,4)之间

• 示例3:

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达","周星驰"]
	print(list1.index("周星驰"))

•结果:

	3      #重复值只查找一个

• list.count(x) 统计指定元素在列表中出现的个数

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达","周星驰"]
	print(list1.count("周星驰"))

•结果:

	2

列表增/删/改

增加

• 通过index修改元素

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达","周星驰"]
	list1[1]=("许君聪")
	print(list1)

•结果:

	['沈腾', '贾玲', '潘斌龙', '周星驰', '吴孟达', '周星驰', '许君聪']

• append() 像列表的最后添加一个元素

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达","周星驰"]
	list1.append("许君聪")
	print(list1)

•结果:

	['沈腾', '贾玲', '潘斌龙', '周星驰', '吴孟达', '周星驰', '许君聪']

• insert(arg1,arg2) 像列表指定位置插入一个元素 参数1:要插入的位置 参数2:要插入的元素

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达","周星驰"]
	list1.insert(3,"许君聪")
	print(list1)
	```
•结果:
```javascript
['沈腾', '贾玲', '潘斌龙', '许君聪', '周星驰', '吴孟达', '周星驰']

• extend(iterable) 使用一个新的序列来扩展当前序列(它会将该序列的中元素添加到列表中) 参数需要传递一个序列


•结果:

	['沈腾', '潘', '佳', '佳', '周星驰', '吴孟达', '周星驰']

• 通过切片来修改(起始就是给切片的内容重新赋值,但是赋值的内容必须是一个序列)

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达","周星驰"]
	list1[1:3]='潘佳佳'
	print(list1)

•结果:

['沈腾', '潘', '佳', '佳', '周星驰', '吴孟达', '周星驰']

修改

• 当设置了步长时,序列中元素的个数必须和切片中元素的个数保持一致

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达","周星驰"]
	list1[::2]=["潘佳佳","岳云鹏","潘长江"]
	print(list1)

•结果:

['潘佳佳', '贾玲', '岳云鹏', '周星驰', '潘长江', '周星驰']

删除

• del list[起始 : 结束]

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达","周星驰"]
	del list1[3]
	print(list1)

•结果:

['沈腾', '贾玲', '潘斌龙', '吴孟达','周星驰']

• remove() 删除指定元素 (如果相同值的元素有多个,只会删除第一个)

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达","周星驰"]
	list1.remove('贾玲')
	print(list1)

•结果:

	['沈腾', '潘斌龙', '周星驰', '吴孟达', '周星驰']

• pop() 根据索引删除并返回指定元素

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达","周星驰"]
	list1.pop(2)
	print(list1)

•结果:

	['沈腾', '贾玲', '周星驰', '吴孟达', '周星驰']

• clear() 清空列表

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达","周星驰"]
	list1.clear()
	print(list1)

•结果:

	[]

列表的其他方法

• reverse() 翻转列表

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达","周星驰"]
	list1.reverse()
	print(list1)

•结果:

	['吴孟达', '周星驰', '周星驰', '沈腾', '潘斌龙', '贾玲']

• sort(key=None,reverse=False) 用来对列表中的元素进行排序 reverse:True反序;False 正序

	list1=["沈腾","贾玲","潘斌龙","周星驰","吴孟达","周星驰"]
	list1.sort()
	print(list1)

•结果:

	['吴孟达', '周星驰', '周星驰', '沈腾', '潘斌龙', '贾玲']

• extend(iterable) 使用一个新的序列来扩展当前序列(它会将该序列的中元素添加到列表中) 参数需要传递一个序列

	list1=["沈腾","贾玲","潘斌龙",]
	list2=["周星驰","吴孟达","周星驰"]
	list1.extend(list2)
	print(list1)

•结果:

	['沈腾', '贾玲', '潘斌龙', '周星驰', '吴孟达', '周星驰']

示例代码

  1. 现在有 a = [1,2,3,4,5,6] 不通过函数的形式实现列表的反转([6,5,4,3,2,1]) 并写出推导过程
    方法1
	a = [1,2,3,4,5,6]
    print(a)
    a.reverse()         #使用list的reverse方法
    print(a)

•结果:

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

方法2

    a = [1, 2, 3, 4, 5, 6]
    print(a)
    b=[]
    for i in a:
        b.insert(0,i)   #将a每个取出的元素插入新列表最前面
    print(b)

•结果:

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

方法3

    a = [1, 2, 3, 4, 5, 6]
    print(a)
    b = a[::-1]         #从右边向左开始切片取值
    print(b)

•结果:

   [1, 2, 3, 4, 5, 6]
   [6, 5, 4, 3, 2, 1] 
  1. 给 用户9次机会 猜1 - 10 个数字随机来猜数字。如果随机的数字和用户输入的数字一致则表示正确,如果不一致则表示错误。最终结果要求用户怎么也猜不对
    import random
    i=1
    user_list=[]
    npc_list=[]
    result=[]
    while i<10:
        i+=1
        user = int(input('请输入数字1~10:'))
        user_list.append(user)
        # print(user_list)
        if user==10:
            Npc = random.randint(1, user-1)
        else:
            Npc = random.randint(user + 1, 10)
        npc_list.append(Npc)
        # print(npc_list)
        if user==Npc:
            result.append("正确")
        else:
            result.append("错误")
    print('你的输入',user_list)
    print('电脑输入',npc_list)
    print('比较结果为',result)

•结果:

请输入数字1~101
请输入数字1~102
请输入数字1~104
请输入数字1~106
请输入数字1~108
请输入数字1~102
请输入数字1~103
请输入数字1~104
请输入数字1~102
你的输入 [1, 2, 4, 6, 8, 2, 3, 10, 2]
电脑输入 [5, 10, 5, 10, 9, 9, 4, 9, 6]
比较结果为 ['错误', '错误', '错误', '错误', '错误', '错误', '错误', '错误', '错误']
  1. 有两个列表 lst1 = [11, 22, 33] lst2 = [22, 33, 44]获取内容相同的元素
    lst1 = [11, 22, 33]
     lst2 = [22, 33, 44]
     for i in lst1:
         for j in lst2:
             if int(i)==int(j):
                 print(i)

•结果:

	22
	33
  1. 现在有8位老师,3个办公室,要求将8位老师随机的分配到三个办公室中,不允许有空办公室
    import random
    Team=['沈腾', '贾玲', '潘斌龙', '许君聪', '周星驰', '吴孟达', '崔志佳','岳云鹏']
    Teacher = random.sample(Team, 8)   #随机取老师名单
    Num = random.randint(1, 4)    #随机取数
    Office = random.sample([Teacher[0:Num], Teacher[Num:Num + 2], Teacher[Num + 2:]], 3)   #按随机数安排办公室人员,并随机取办公室编号。
    print('第一间办公室人员:',Office[0])
    print('第二间办公室人员:',Office[1])
    print('第三间办公室人员:',Office[2])   

•结果:

第一间办公室人员: ['潘斌龙', '崔志佳', '沈腾']
第二间办公室人员: ['周星驰', '贾玲', '吴孟达']
第三间办公室人员: ['许君聪', '岳云鹏']

本文地址:https://blog.csdn.net/vipjzl/article/details/110221739