zoukankan      html  css  js  c++  java
  • 迭代器,三元表达式,列表生成式,字典生成式,生成器,递归(没深入理解)

    06.03自我总结

    1.迭代器

    可迭代对象:一个对象能够导出内置函数_iter_该对象为迭代器

    迭代器对象:一个对象能够导出内置函数_iter_和_next_该对象为迭代对象

    迭代器里面的内容用一次就没了

    #for 循环的原理
    s = 'hello'
    iter_s = s.__iter__()
    
    while True:
        try:
            print(iter_s.__next__())
        except StopIteration:
            break                     #如果报错停止
    

    2.三元表达式

    1.不是很实用,用于简单的if.... else......

    for a in range(1,19):
        if a == 10:
            print('等于10')
        else:
            print('不等于10')
     #三元表达式
    for a in range(1,19):
        print('等于10') if a ==10 else print('不等于10')
    

    3.列表生成式

    lis = [i for i in range(1,10)]
    print(lis)
    #[1, 2, 3, 4, 5, 6, 7, 8, 9]
    

    4.字典生成式

    1.formkeys

    dic = dict.fromkeys([1,2,1],1) #他会强制吧前面的变成集合
    print(dic)
    #{1: 1, 2: 1}
    

    2.用于列表生成式类似的办法生成

    dic = {i:i for i in range(1,10)} #for 前面为每次生成的内容
    print(dic)
    #{1: 1, 2: 2, 3: 3, 4: 4, 5: 5, 6: 6, 7: 7, 8: 8, 9: 9}
    

    3.用zip()生成

    keys = ['name', 'age', 'gender']
    values = ['nick', 19, 'male']
    a = zip(keys,values)
    print(a)   #<zip object at 0x000000000265DB48> 只是个地址可以减少内存
    dic = {x:y for x,y in a}
    print(dic)  #{'name': 'nick', 'age': 19, 'gender': 'male'}
    
    #我们可以这样写
    keys = ['name', 'age', 'gender',1]
    values = ['nick',i9, 'male']
    dic ={x:y for x,y in zip(keys,values)}
    print(dic)
     #{'name': 'nick', 'age': 19, 'gender': 'male'}
    #从这里我们可以知道zip他会根据两个或多个存多个值按照FOR循环,从左往右一一对应组成键值对,按最小长度的值来决定键值对的个数
    

    5.生成器

    1.yield关键字

    yield的英文单词意思是生产,在函数中但凡出现yield关键字,再调用函数,就不会继续执行函数体代码,而是会返回一个值

    他与return区别在于他不会停止,而且return返回的是个值,而他返回的是个代送对象,用通过for来把他值提取出来

    #用yield来写出range函数
    def range(end,start=0,step=1):
        if start !=0:
            end,start =start,end
            if step >0:
                count = start
                while count < end:
                    yield count
                    count += step
            elif step <0:
                count = end
                while count >= start:
                    yield count
                    count += step               
            else:
                raise('不能为0')
            return
        count = start
        while count < end:
            yield count
            count += step
    

    2.生成器

    • 把列表推导式的[]换成()就是生成器表达式,这样打印出来的是个路径,还是个跌送对象,我们可以用for 或者next进行提取

    • 优点:省内存,一次只产生一个值在内存中

      generator = (i for i in range(10))
      print(generator.__next__())
      # 0
      

    6.递归

    函数的嵌套调用是:函数嵌套函数。函数的递归调用:它是一种特殊的嵌套调用,但是它在调用一个函数的过程中,又直接或间接地调用了它自身。

    如简单的

    def func_1():
        print('1')
    	func_1()
    func_1()  #会进入死循环
    

    1.直接调用

    接调用指的是:直接在函数内部调用函数自身。

    def foo(n):
        print('from foo',n)
        foo(n+1)
    foo(0)
    

    2.间接调用

    间接调用指的是:不在原函数体内调用函数自身,而是通过其他的方法间接调用函数自身。

    def bar():
        print('from bar')
        foo()
        
    def foo():
        print('from foo')
        bar()
        
    bar()
    

    3.递归必须要有两个明确的阶段(暂时没法深入理解,明天补充)

    1. 递推:一层一层递归调用下去,进入下一层递归的问题规模都将会减小
    2. 回溯:递归必须要有一个明确的结束条件,在满足该条件开始一层一层回溯。
  • 相关阅读:
    测试可以自动化,日常工作也可以自动化,autoit帮你搞定!
    工作了几年的IT人想要创业,必看的失败经验
    使用autoit,可以节省您很多时间
    美容院会籍管理,看着简单,其实很复杂
    简历,求职求项目,硕士4年工作经验2年管理经验
    maven+svn+hudson+weblogic构建持续集成环境
    快速开发框架V0.001(免费、100%开源)
    进销存管理系统的设计与实现
    窗体的位置startposition manual
    破解网页文章无法复制方法全集合
  • 原文地址:https://www.cnblogs.com/pythonywy/p/10970185.html
Copyright © 2011-2022 走看看