• python自学入门(打卡十二)2022-12-04


    “”““迭代器Iterator:统一了不同数据类型的遍历工作””"
    “”"“迭代器特性:迭代器本身可迭代
    1.只能向前不能反复
    2.特别节省内存
    3,惰性机制
    “””

    “”“生成器generator本身就是迭代器
    创建生成器的两种方案
    1.生成器函数
    关键字yield的作用:
    (1)只有执行到next时才会返回数据 、
    (2)分段执行函数(return关键字后面代码不会执行,但是yield后面还可以执行到下一个yield)
    2.生成器表达式 (数据 for循环 if) 、一次性的、节省内存
    “””

    生成器实操:从工厂买10000件衣服,一次出50件

    def order():
        list =[]
        for i in range(10000):
            list.append(f"第{i}件衣服")
            if len(list) == 50:
                yield list
                #下一次拿数据从这接着开始
                list=[]
    gen = order()
    print(gen.__next__()) #取第0-49件
    print(gen.__next__()) #取第50-99件
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    “”““推导式:字典、列表、集合推导式
    元组没有推导式,叫生成器表达式””"

    内置函数zip:把多个可迭代内容组合

    #打印出对应的人名、年龄、作品
    list1 = ["赵本山","周杰伦"]
    list2 = [66,48]
    list3 = ["卖拐","发如雪"]
    result=[]
    
    #不用zip
    # for i in range(len(list1)):
    #     first = list1[i]
    #     second = list2[i]
    #     third = list3[i]
    #     result.append((first,second,third))
    # print(result) #[('赵本山', 66, '卖拐'), ('周杰伦', 48, '发如雪')]
    
    #使用内置函数zip
    result = zip(list1,list2,list3)
    print(type(result)) #
    lst = list(result) #转换为list类型
    print(lst)#[('赵本山', 66, '卖拐'), ('周杰伦', 48, '发如雪')]
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19

    内置函数sorted

    # list =[11,22,6,7,8,444]
    # s=sorted(list)
    # print(s) ##[6, 7, 8, 11, 22, 444]
    # # s.reverse() #reverse函数是直接把s改了
    # # print(s) #[444, 22, 11, 8, 7, 6]
    
    • 1
    • 2
    • 3
    • 4
    • 5

    sorted与lambda的配套使用

    #将数据按照年龄排序
    lst =[
        {"name":"张三","age":33},
        {"name":"李四","age":18},
        {"name":"王五","age":53}
    ]
    s = sorted(lst,key=lambda d:d["age"]) #d代表字典,因为lst里的每条数据是字典
    print(s) #[{'name': '李四', 'age': 18}, {'name': '张三', 'age': 33}, {'name': '王五', 'age': 53}]
    
    #根据年龄从大到小排序
    s = sorted(lst,key=lambda d:d["age"],reverse=True) #d代表字典,因为lst里的每条数据是字典
    print(s) #[{'name': '王五', 'age': 53}, {'name': '张三', 'age': 33}, {'name': '李四', 'age': 18}]
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
  • 相关阅读:
    什么是整体设备效率(OEE)?
    如何使用ChatGPT编写更好的代码
    4-7:用Redis优化登陆模块
    数据采集:智能制造的基础环节
    互联网摸鱼日报(2023-10-20)
    机器学习-聚类算法
    DispatcherServlet初始化之遍历HandlerMethod
    产品设计的六大要素
    Java版分布式微服务云开发架构 Spring Cloud+Spring Boot+Mybatis 电子招标采购系统功能清单
    11.12 - 每日一题 - 408
  • 原文地址:https://blog.csdn.net/weixin_42231208/article/details/128172287