叠加装饰器,三元表达,生成,调用,递归

叠加多个装饰器的加载、运行分析

def deco1(func1): # func1 = wrapper2的内存地址
    def wrapper1(*args,**kwargs):
        print('正在运行===>deco1.wrapper1')
        res1=func1(*args,**kwargs)
        return res1
    return wrapper1

def deco2(func2): # func2 = wrapper3的内存地址
    def wrapper2(*args,**kwargs):
        print('正在运行===>deco2.wrapper2')
        res2=func2(*args,**kwargs)
        return res2
    return wrapper2

def deco3(x):
    def outter3(func3): # func3=被装饰对象index函数的内存地址
        def wrapper3(*args,**kwargs):
            print('正在运行===>deco3.outter3.wrapper3')
            res3=func3(*args,**kwargs)
            return res3
        return wrapper3
    return outter3


# 加载顺序自下而上(了解)
@deco1      # index=deco1(wrapper2的内存地址)        ===> index=wrapper1的内存地址
@deco2      # index=deco2(wrapper3的内存地址)        ===> index=wrapper2的内存地址
@deco3(111) # ===>@outter3===> index=outter3(index) ===> index=wrapper3的内存地址
def index(x,y):
    print('from index %s:%s' %(x,y))

# 执行顺序自上而下的,即wraper1-》wrapper2-》wrapper3
index(1,2) 

yield :可以返回多个返回值

def dog(name):
    food_list=[]
    print('道哥%s准备吃东西啦...' %name)
    while True:
        x = yield food_list # x = '肉包子'
        print('道哥%s吃了 %s' %(name,x))
        food_list.append(x) # ['一根骨头','肉包子']

 g=dog('alex')
 res=g.send(None)  # next(g)
 print(res)

 res=g.send('一根骨头')
 print(res)
三元表达式:
  语法格式: 条件成立时要返回的值 if 条件 else 条件不成立时要返回的值
def func():
    x = 1 if 1 > 3 else 3
    print(x)

func()

生成式

  1、列表生成式

l = ['alex_dsb', 'lxx_dsb', 'wxx_dsb', "xxq_dsb", 'egon']
new_l=[]
for name in l:
    if name.endswith('dsb'):
        new_l.append(name)


new_l=[name for name in l if name.endswith('dsb')]
new_l=[name for name in l]

print(new_l)

  2、字典生成式 

keys=['name','age','gender']
dic={key:None for key in keys}
print(dic)

items=[('name','egon'),('age',18),('gender','male')]
res={k:v for k,v in items if k != 'gender'}
print(res)

  3、集合生成式

keys=['name','age','gender']
set1={key for key in keys}
print(set1,type(set1))

递归的定义:函数的递归调用:是函数嵌套调用的一种特殊形式
具体是指:在调用一个函数的过程中又直接或者间接地调用到本身

代码的循环运行的方案有两种
方式一:while、for循环
while True:
    print(1111)
    print(2222)
    print(3333)
方式二:递归的本质就是循环:
def f1():
    print(1111)
    print(2222)
    print(3333)
    f1()
f1()

强调:递归调用不应该无限地调用下去,必须在满足某种条件下结束递归调用

return 可以结束调用

def f1(n):
    if n == 10:
        return
    print(n)
    n+=1
    f1(n)

f1(0)
递归的两个阶段:
回溯:一层一层调用下去
递推:满足某种结束条件,结束递归调用,然后一层一层返回
l=[1,2,[3,[4,[5,[6,[7,[8,[9,10,11,[12,[13,]]]]]]]]]]

def f1(list1):
    for x in list1:
        if type(x) is list:
            f1(x)
        else:
            print(x)

f1(l)

 

posted @ 2020-03-25 14:12  zhw_sylvia  阅读(127)  评论(0编辑  收藏  举报