首页 > 其他 > 详细

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

时间:2020-03-25 14:24:22      阅读:44      评论:0      收藏:0      [点我收藏+]

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

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)

 

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

原文:https://www.cnblogs.com/zhenghuiwen/p/12565961.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!