昨日回顾

  1. 可迭代对象:

    • 可以更新迭代的实实在在的值。
    • 内部含有'__iter__'方法。
    • str、tuple、dict、set、range
    • 优点:操作方法多,灵活直观
    • 缺点:占用内存。
  2. 迭代器:

    • 可以更新迭代的一个工具(数据结构)
    • 内部含有'__iter__'并且含有'__next__'方法。
    • 文件句柄
    • 优点:节省内存,惰性机制
    • 缺点:不直观,速度相对慢,操作方法单一,不走回头路。
  3. 格式化输出

  4. 函数名的运用:就是个变量

  5. 作用域的坑

  6. 练习题

    #看代码写结果
    def func1():
    print('in func1') def func2(x):
    print('in func2')
    return x def func3(y):
    print('in func3')
    return y ret=func2(func1)
    ret()
    ret2=func3(func2)
    ret3=ret2(func1)
    ret3()
    '''
    in func2
    in func1
    in func3
    in func2
    in func1
    '''
    #看代码写结果
    def func():
    for item in range(10):
    pass
    print(item)
    func()
    '''
    9
    '''
    #看代码写结果
    l1=[]
    def func4(args):
    l1.append(args)
    return l1
    print(func4(1))
    print(func4(2))
    print(func4(3))
    '''
    [1]
    [1,2]
    [1,2,3]
    '''

    #写函数计算阶乘
    def cal(num):
    count=1
    for i in range(num,0,-1):
    count = count * i
    return count
    print(cal(3))

今日内容

  1. 生成器

    #吃包子,5000个,函数剩下没吃完不好算
    def func1():
    l1=[]
    for i in range():
    l1.append(f'{i}号包子')
    return l1
    ret=func()
    print()#就是个可迭代对象 #吃包子,吃一个做一个,生成器
    def gen_func1():
    for i in range(1,5001):
    yield f'{i}号包子'
    ret=gen_func1()
    for i in range(200):
    print(next(ret)) ##next一次做一个包子
    #就是个迭代器
    • 什么是生成器:生成器和迭代器可以看作一种,生成器的本质就是迭代器。

    • 生成器迭代器区别:生成器是我们自己用python代码构建的数据结构。而迭代器都是提供或转换来的。

    • 获取方式

      • 生成器函数

        #以往见到的函数
        def func():
        print(111)
        print(222)
        return 3
        ret=func()
        print(ret)
        '''
        111
        222
        3
        ''' #生成器函数
        def func():
        print(111)
        print(222)
        yield 3
        yield 4
        yield 5
        ret=func()
        print(ret) #<generator object func at 0x000002B0868AB0F8>
        print(next(ret)) #一个next对应一个yield
        # 111
        # 222
        # 3
        print(next(ret)) # 4
        print(next(ret)) # 5
      • 生成器表达式

      • python内部提供的一些

    • yield

    • yield、return对比

      • yield:函数中有yield就一定式生成器函数而不是函数了。生成器函数可存在多个yield,yield不结束生成器函数。
      • return:函数中只存在一个return,结束函数返回值。
    • yield from

      #yield from
      def func2():
      l1=[1,2,3,4,5]
      yield from l1
      ##这样会从列表中拿出单一的元素,将l1这个列表变成了一个迭代器
      ret=func2()
      print(next(ret))
  2. 生成器表达式、列表推导式

    • 列表推导式:用一行代码构建一个比较复杂有规律的列表。

      l1=[i for i in range(1,11)]
      • 列表推导式分两类:

        • 循环模式:

          [变量(加工后的变量)for 变量 in iterable]

        • 筛选模式:

          #30以内能被3整除的数
          l1=[i for i in range(1,31) if i%3==0]
          #过滤长度小于3的字符串列表,并将剩下的转换成大写
          l1=['sadjiwqf','sd','a','dqwdj','asd','wqewr','henri']
          print([i.upper() for i in l1 if len(i)>=3])
    • 生成器表达式:与列表推导式的写法几乎一样,把[]变成()就变成了生成器表达式,非常节省内存,也有筛选模式和循环模式。

      obj=(i for i in range(1,11))
      next(obj)
    • 小结:

      • 列表推导式:

        • 缺点:有毒,列表推导式只能构建比较有规律的列表。超过三层循环才能构建成功的不建议用,另外debug模式查找错误不行。

        • 优点:简单、装逼。

          #装逼
          #构建一个列表[2,3,4,5,6,7,8,9,10,'J','Q','K','A']
          l1=[i for i in range(2,11)]+list('JQKA')
          print(l1)
      • 列表推导式与生成器表达式区别

        • 写法上:[],()
        • iterable、iterator
      • (了解)还有字典推导式、集合推导式,都是一行构建

  3. 内置函数I

    python提供了68个内置函数

    今天的这部分大部分了解即可。

    • eval()剥去字符串的外衣,运算里面的代码。最好不要使用

      #eval
      s1='1+3'
      print(eval(s1)) #4
    • exec():与eval()几乎一样,但是是处理代码流的。

    • hash():获取一个对象的哈希值。int str bool等

    • help():获取对象的使用方法

    • callable():判断对象是否可调用

今日总结

  1. 生成器:我们用python代码自己构建的
  2. 生成器函数yield
  3. yield与return区别、yield from
  4. 列表推导式、生成器表达式
  5. 内置函数:学了一些了解即可的

明天学习

  1. lambda表达式
  2. 内置函数II
  3. 闭包

代码总行数1752+135=1887行

python12day的更多相关文章

随机推荐

  1. 【LeetCode】73. Set Matrix Zeroes 解题报告(Python & C++)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 原地操作 新建数组 队列 日期 题目地址:https ...

  2. 【LeetCode】659. Split Array into Consecutive Subsequences 解题报告(Python)

    [LeetCode]659. Split Array into Consecutive Subsequences 解题报告(Python) 标签(空格分隔): LeetCode 作者: 负雪明烛 id ...

  3. 【LeetCode】592. Fraction Addition and Subtraction 解题报告(Python)

    [LeetCode]592. Fraction Addition and Subtraction 解题报告(Python) 标签(空格分隔): LeetCode 作者: 负雪明烛 id: fuxuem ...

  4. Hive SQL优化思路

    Hive的优化主要分为:配置优化.SQL语句优化.任务优化等方案.其中在开发过程中主要涉及到的可能是SQL优化这块. 优化的核心思想是: 减少数据量(例如分区.列剪裁) 避免数据倾斜(例如加参数.Ke ...

  5. Missing Data in Kernel PCA

    目录 引 主要内容 关于缺失数据的导数 附录 极大似然估计 代码 Sanguinetti G, Lawrence N D. Missing data in kernel PCA[J]. europea ...

  6. HTML5 +Java基础 大一结业认证考试试题 - 云南农业职业技术学院 - 互联网技术学院 - 美和易思校企合作专业

     第1题 [单选题][0.33分][概念理解] 关于java中的逻辑运算符,下列说法正确的是 逻辑运算符||.&&.!都是用于连接两个关系表达式</p> 当&&am ...

  7. MySQL数据操作与查询笔记 • 【第6章 聚合函数和分组查询】

    全部章节   >>>> 本章目录 6.1 sum.max 和 min 聚合函数 6.1.1 聚合函数介绍 6.1.2 sum 函数 6.1.3 max/min 函数 6.2 a ...

  8. Git创建本地仓库

    使用Git创建本地仓库, 可以记录文本文件变化, 这里以自己的文章为例, 利用TortoiseGit工具创建一个本地Git仓库. 1. 切换到需要创建仓库的目录下, 比如:D:\MyDoc\Devel ...

  9. Ranger知识地图

    自己总结的Ranger的学习路线和知识点, 提供给感兴趣的同学入门参考之用. Ranger入门路线 1.准备能够上网的电脑,Eclisp开发环境,Linux服务器等: 2.掌握Hadoop(HDFS/ ...

  10. 4 - 基于ELK的ElasticSearch 7.8.x技术整理 - 高级篇( 续 ) - 更新完毕

    0.前言 这里面一些理论和前面的知识点挂钩的,所以:建议看一下另外3篇知识内容 基础篇:https://www.cnblogs.com/xiegongzi/p/15684307.html java操作 ...