基础语言-第七天-列表相关操作

列表相关操作

一、列表相关函数

  • 比较大小

    • 判断是否相等 - ==、!=
    • 比较列表大小 - >、<、>=、<=

    注意:列表比较大小,只能是两个列表进行比较

    比较规则:比较第一对不相等的元素的大小(相同位置的元素是一对儿)

    # 案例:
    print([10, 2000, 30992, 42220, 522340] >[100, 1])    #False
    print([10, 20, 30] > [10, 2, 300])    # True
    print([10, 'abc', 20, 30] > [10, 23, 9])  
    # 报错:'>' not supported between instances of 'str' and 'int'
    
  • 相关函数

    • sum(列表)-求列表中所有元素的数值和(列表中元素必须是数字)
    scores = [19, 34, 89, 67, 34, 99]
    print(sum(scores))   # 342
    print(sum(range(1, 101)))  # 5050
    
    • max(列表)、min(列表) - 获取列表中的最大、最小元素(列表中的元素支持比较运算)
    scores = [19, 34, 89, 67, 34, 99]
    print(max(scores))   # 99
    print(min(scores))   # 19
    
    • sorted(列表) - 将列表中的元素从小到大排序,产生一个新的列表

      sorted(列表,reverse=True) - 将列表中的元素从大到小排序,产生一个新的列表

    scores = [19, 34, 89, 67, 34, 99]
    new_scores = sorted(scores)
    print(scores)    # [19, 34, 89, 67, 34, 99]
    print(new_scores)    # [19, 34, 34, 67, 89, 99]
    new_scores = sorted(scores, reverse=True)    # [99, 89, 67, 34, 34, 19]
    
    • len(列表) - 统计列表中元素的个数

    • list(列表) - 将指定序列转换成列表

      任何序列都可以转换成列表,转换的时候直接将序列中的元素作为列表的元素

    print(list('abc'))    # ['a', 'b', 'c']
    print(list(range(10,15)))    # [10, 11, 12, 13, 14]
    

二、列表相关方法

方法的使用套路:列表.xxx()

  • 列表.clear() - 清空列表

    nums = [20, 89, 23]
    print(nums)     # [20, 89, 23]
    
    nums.clear()
    print(nums)     # []
    
  • 列表.copy() - 拷贝(浅拷贝)原列表产生一个一模一样的新列表,将新列表返回

    • 用变量保存数据的时候,变量真正保存的其实是数据在内存中的地址;

    • 当用一个变量直接给另外一个变量赋值的时候,赋的其实是变量中保存地址,赋值后两

      个变量指向的是同一块内存。

    • 深拷贝会拷贝列表里所有的,包括列表里的列表

    a = [20, 89, 23]
    b = a
    c = a.copy()            # 列表[:]、列表*1、列表+[] 都是浅拷贝
    
    print('a:', a)    # a: [20, 89, 23]
    print('b:', b)    # b: [20, 89, 23]
    print('c:', c)    # c: [20, 89, 23]
    
    print('------------------------------------华丽的分割线-----------------------------------')
    a.append(100)
    print('a:', a)    # a: [20, 89, 23, 100]
    print('b:', b)    # b: [20, 89, 23, 100]
    print('c:', c)    # c: [20, 89, 23]
    
  • 列表.count(数据) - 统计列表中指定数据出现的次数(数据的个数)

    nums = [10, 34, 45, 90, 10, 45, 45, 78, 45]
    print(nums.count(10))   # 2
    print(nums.count(45))   # 4
    print(nums.count(100))  # 0
    
  • 列表.extend(序列) - 将序列中所有的元素全部添加到列表的最后

    nums = [10, 20, 30]
    nums.extend('abc')
    print(nums)     # [10, 20, 30, 'a', 'b', 'c']
    
    nums = [10, 20, 30]
    nums.extend([100, 200])
    print(nums)     # [10, 20, 30, 100, 200]
    
  • 列表.index(数据) - 获取指定数据在列表中的第一个下标(如果数据不存在会报错)

    nums = [10, 34, 45, 90, 10, 45, 45, 78, 45]
    print(nums.index(34))       # 1
    print(nums.index(45))       # 2
    # print(nums.index(100))    # 报错!
    
  • 列表.reverse() - 列表倒序

    nums = [10, 34, 45, 90, 10, 45, 45, 78, 45]
    nums.reverse()
    print(nums)     # [45, 78, 45, 45, 10, 90, 45, 34, 10]
    
  • sort 和 sorted区别

    • 列表.sort() - 将列表中的元素升序排序(直接修改原列表元素的顺序,不会产生新的列表)

      列表.sort(reverse=True)

    • sorted(序列) - 将序列中的元素升序排序(不会修改原序列中元素的顺序,会产生一个新的列表)

      sorted(序列, reverse=True)

    # 举例
    nums = [10, 34, 45, 90, 10, 45, 45, 78, 45]
    nums.sort()
    print(nums)     # [10, 10, 34, 45, 45, 45, 45, 78, 90]
    
    nums = [10, 34, 45, 90, 10, 45, 45, 78, 45]
    new_nums = sorted(nums)
    print(new_nums)     # [10, 10, 34, 45, 45, 45, 45, 78, 90]
    

三、列表推导式

  • 结构1-------------[表达式 for 变量 in 序列]

    原理: 让变量去序列中取值,每取一个值就计算一次表达式的结果,并且将计算的结果作为列表中的元素。

    # 举例
    list1 = [10 for i in range(5)]
    print(list1)    # [10, 10, 10, 10, 10]
    
    list2 = [i + 2 for i in range(5)]
    print(list2)    # [2, 3, 4, 5, 6]
    
    # 应用:基于原序列中的元素得到新的序列(对序列中元素进行统一变换得到新元素)
    
    # 练习:提取nums中所有元素的个位数
    # [18, 29, 892, 78, 91, 56] -> [8, 9, 2, 8, 1, 6]
    nums = [18, 29, 892, 78, 91, 56]
    new_nums = [x % 10 for x in nums]
    print(new_nums)    # [8, 9, 2, 8, 1, 6]
    
    # 练习2:使用列表推导式让所有员工的薪资提高10%
    money = [18290, 10000, 8921, 7828, 12000, 5600]
    new_money = [x * 1.1 for x in money]
    print(new_money)    # [20119.0, 11000.0, 9813.1, 8610.8, 13200.0, 6160.0]
    
  • 结构2-------------[表达式 for 变量 in 序列 if 条件语句]

    原理:让变量去序列中取值,一个一个取,取完为止,每取一个值就判断一次条件语句是否成立,如果成立就

    计算一次表达式的结果,并且将结果作为列表的元素。

    # 举例
    list1 = [x for x in range(5, 15) if x % 2]
    print(list1)  # [5, 7, 9, 11, 13]
    
    # 应用:数据筛选
    # 案例1:获取nums中所有的偶数
    nums = [18, 90, 43, 67, 88, 19, 84]
    even_nums = [i for i in nums if i % 2 == 0]
    print(even_nums)   # [18, 90, 88, 84]
    
    # 案例2:获取列表中所有数字,并且将数字都乘以10
    list1 = [10, 2.25, 'abc', False, True, 'as12', 4, 2.5]
    
    # 法1
    new_list1 = [i * 10 for i in list1 if type(i) == int or type(i) == float]
    # 法2
    result = [i * 10 for i in list1 if type(i) in [int, float]]
    print(result)     # [100, 22.5, 40, 25.0]
    print(new_list1)  # [100, 22.5, 40, 25.0]
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值