欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

学习python的第十六天(迭代器,三元表达式,列表生成式,字典生成式,生成器,递归(没深入理解)

程序员文章站 2022-03-22 11:22:34
06.03自我总结 1.迭代器 迭代器:一个对象能够导出内置函数\_iter\_该对象为迭代器 可迭代对象:一个对象能够导出内置函数\_iter\_和\_next\_该对象为迭代对象 迭代器里面的内容用一次就没了 2.三元表达式 1.不是很实用,用于简单的if.... else...... 3.列表 ......

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. 回溯:递归必须要有一个明确的结束条件,在满足该条件开始一层一层回溯。