zoukankan      html  css  js  c++  java
  • 叠加多个装饰器、yield表达式、三元表达式、生成式、函数的递归

    叠加多个装饰器

    # 一、叠加多个装饰器的加载、运行分析(了解***)

    # 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) # wrapper1(1,2)

    yield表达式

    # x=yield 返回值

    # 一:
    # def dog(name):
    # print('道哥%s准备吃东西啦...' %name)
    # while True:
    # # x拿到的是yield接收到的值
    # x = yield # x = '肉包子'
    # print('道哥%s吃了 %s' %(name,x))
    #
    #
    # g=dog('alex')
    # g.send(None) # 等同于next(g)
    #
    # g.send(['一根骨头','aaa'])
    # # g.send('肉包子')
    # # g.send('一同泔水')
    # # g.close()
    # # g.send('1111') # 关闭之后无法传值

    # 二:
    # def dog(name):
    # food_list=[]
    # print('道哥%s准备吃东西啦...' %name)
    # while True:
    # # x拿到的是yield接收到的值
    # 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)
    #
    # res=g.send('肉包子')
    # print(res)
    # # g.send('一同泔水')

    # def func():
    # print('start.....')
    # x=yield 1111 # x='xxxxx'
    # print('哈哈哈啊哈')
    # print('哈哈哈啊哈')
    # print('哈哈哈啊哈')
    # print('哈哈哈啊哈')
    # yield 22222

    # g=func()
    # res=next(g)
    # print(res)
    #
    # res=g.send('xxxxx')
    # print(res)

    三元表达式

    # 针对以下需求
    # def func(x,y):
    # if x > y:
    # return x
    # else:
    # return y
    #
    # res=func(1,2)
    # print(res)

    # 三元表达式
    # 语法格式: 条件成立时要返回的值 if 条件 else 条件不成立时要返回的值
    # x=1
    # y=2

    # res=x if x > y else y
    # print(res)

    # res=111111 if 'egon' == 'egon' else 2222222222
    # print(res)

    # 应用举例
    # def func():
    # # if 1 > 3:
    # # x=1
    # # else:
    # # x=3
    #
    # x = 1 if 1 > 3 else 3

    生成式

    # 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)

    # 把所有小写字母全变成大写
    # new_l=[name.upper() for name in l]
    # print(new_l)

    # 把所有的名字去掉后缀_dsb
    # new_l=[name.replace('_dsb','') 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))

    # 4、生成器表达式
    # g=(i for i in range(10) if i > 3)
    # !!!!!!!!!!!强调!!!!!!!!!!!!!!!
    # 此刻g内部一个值也没有

    # print(g,type(g))

    # print(g)
    # print(next(g))
    # print(next(g))
    # print(next(g))
    # print(next(g))
    # print(next(g))
    # print(next(g))
    # print(next(g))


    # with open('笔记.txt', mode='rt', encoding='utf-8') as f:
    # 方式一:
    # res=0
    # for line in f:
    # res+=len(line)
    # print(res)

    # 方式二:
    # res=sum([len(line) for line in f])
    # print(res)

    # 方式三 :效率最高
    # res = sum((len(line) for line in f))
    # 上述可以简写为如下形式
    # res = sum(len(line) for line in f)
    # print(res)

    函数的递归

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

    # 直接调用本身
    # def f1():
    # print('是我是我还是我')
    # f1()
    # f1()

    # 间接接调用本身
    # def f1():
    # print('===>f1')
    # f2()
    #
    # def f2():
    # print('===>f2')
    # f1()
    #
    # f1()

    # 一段代码的循环运行的方案有两种
    # 方式一:while、for循环
    # while True:
    # print(1111)
    # print(2222)
    # print(3333)

    # 方式二:递归的本质就是循环:
    # def f1():
    # print(1111)
    # print(2222)
    # print(3333)
    # f1()
    # f1()

    # 二:需要强调的的一点是:
    # 递归调用不应该无限地调用下去,必须在满足某种条件下结束递归调用
    # n=0
    # while n < 10:
    # print(n)
    # n+=1

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

    # 三:递归的两个阶段
    # 回溯:一层一层调用下去
    # 递推:满足某种结束条件,结束递归调用,然后一层一层返回

    # age(5) = age(4) + 10
    # age(4) = age(3) + 10
    # age(3) = age(2) + 10
    # age(2) = age(1) + 10
    # age(1) = 18

    # def age(n):
    # if n == 1:
    # return 18
    # return age(n-1) + 10
    #
    #
    # res=age(5)
    # print(res)

    # 四:递归的应用
    # 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)
  • 相关阅读:
    Head First设计模式(观察者模式Observer)
    Head First设计模式(装饰者模式)
    Head First设计模式
    Head First设计模式 单件模式 独一无二的对象
    .NET 设计规范.NET约定、惯用法与模式8.使用规范
    .NET 设计规范.NET约定、惯用法与模式附录:C#编程风格约定
    设计模式 一 引言
    .NET 设计规范.NET约定、惯用法与模式7.异常
    Head First设计模式 工厂模式 烘烤OO的精华
    前端IDE中Emmet插件快捷输入HTML代码
  • 原文地址:https://www.cnblogs.com/0B0S/p/12566208.html
Copyright © 2011-2022 走看看