迭代器,三元表达式,列表生成式,字典生成式,生成器,递归(没深入理解)

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. 回溯:递归必须要有一个明确的结束条件,在满足该条件开始一层一层回溯。
posted @ 2019-06-03 21:30  小小咸鱼YwY  阅读(553)  评论(0编辑  收藏  举报