# def wrapper(f):
# def inner(*args,**kwargs):
# print('在被装饰的函数执行之前做的事')
# res = f(*args,**kwargs)
# print('在被装饰的函数执行之后做的事')
# return res
# return inner
# @wrapper # holiday = wrapper(holiday) 这时holiday == inner
# def holiday(day):
# print('全体放假%s天'%day)
# return '好开心'
# ret = holiday(3)
# print(ret) # def outer(*args,**kwargs):
# print(args,kwargs)
# print(*args)
# def inner(*args):
# print('inner:', args)
# inner(*args)
# outer(1,2,3,4,a = 1,b = 2) # def wahaha():
# '''
# 一个打印娃哈哈的函数
# :return:
# '''
# print('娃哈哈')
# print(wahaha.__name__) # 查看字符串格式的函数名
# print(wahaha.__doc__) # document (查看函数的注释) # from functools import wraps
# def wrapper(f): # f = holiday
# @wraps(f) # 加上这句话之后, holiday 就是holiday 不是inner了
# def inner(*args,**kwargs):
# print('在被装饰的函数执行之前做的事')
# res = f(*args,**kwargs)
# print('在被装饰的函数执行之后做的事')
# return res
# return inner
# @wrapper # holiday = wrapper(holiday) 这时holiday == inner ,这时还没加上面那句话
# def holiday(day):
# print('全体放假%s天'%day)
# return '好开心'
# ret = holiday(3)
# print(holiday.__name__) # 输出inner,加了上面那句话之后输出 holiday # ---------------------------------------------------------------------------------------------------- # # 带参数的装饰器 # 500个函数
#
# import time
# FLAG = True
# def timmer_out(flag):
# '''
# 计算机函数执行时间
# :param flag:flag为真时,运行这个函数,为假时不运行
# :return:
# '''
# def timmer(func):
# def inner(*args,**kwargs):
# if FLAG:
# start_time = time.time()
# ret = func(*args,**kwargs)
# end_time = time.time()
# print(end_time - start_time)
# return ret
# else:
# ret = func(*args, **kwargs)
# return ret
# return inner
# return timmer
# @timmer_out(FLAG) # 先调用timmer_out(FLAG),返回的结果为timmer, 加了@ 之后就等于 @timmer,就等于wahaha = timmer(wahaha)
# # 上个式子等价于:
# # timmer = timmer_out(FLAG)
# #@timmer
#
# def wahaha():
# time.sleep(0.1)
# print('娃哈哈')
# @timmer_out(FLAG)
# def erguotou():
# time.sleep(0.1)
# print('二锅头')
# wahaha()
# erguotou() # 多个装饰器装饰一个函数 #
# def wrapper1(func): # func --> f
# def inner1():
# print('wrapper1,before func')
# func() # f
# print('wrapper1,after func')
# return inner1
#
# def wrapper2(func): # func --> inner1
# def inner2():
# print('wrapper2, before func')
# func() # 其实是 inner1()
# print('wrapper2, after func')
# return inner2
#
# @wrapper2 # f = wrapper2(f) --> wrapper2(inner1), 返回的inner2,故 f == inner2
# @wrapper1 # f = wrapper1(f) 返回的inner1,故 f == inner1
#
# # 先找最近的函数,wrapper2没找到, wrapper1先找的f(),然后wrapper2又找的
# def f():
# print('in f')
#
# f() # --> inner2() # ---------------------------------------------------------------------------------- #
# 三个 def wrapper1(func):
def inner1():
print('wrapper1,before func')
ret = func()
print('wrapper1,after func')
return ret
return inner1 def wrapper2(func):
def inner2():
print('wrapper2, before func')
ret = func()
print('wrapper2, after func')
return ret
return inner2 def wrapper3(func):
def inner3():
print('wrapper3, before func')
ret = func()
print('wrapper3, after func')
return ret
return inner3 @wrapper3
@wrapper2
@wrapper1
def f():
print('in f')
return '哈哈哈'
print(f()) # 记录用户的登录情况 and 计算这个函数的执行时间

python学习之老男孩python全栈第九期_day012知识点总结的更多相关文章

  1. python学习之老男孩python全栈第九期_day027知识点总结——反射、类的内置方法

    一. 反射 ''' # isinstance class A:pass class B(A):pass a = A() print(isinstance(a,A)) # 判断对象和类的关系 print ...

  2. python学习之老男孩python全栈第九期_day023知识点总结——类和对象命名空间、组合

    一. 类和对象命名空间类里 可以定义两种属性: 1. 静态属性 2. 动态属性 class Course: language = 'Chinese' def __init__(self, teache ...

  3. python学习之老男孩python全栈第九期_day019知识点总结——collections模块、时间模块、random模块、os模块、sys模块

    一. collections模块 在内置数据类型(dict.list.set.tuple)的基础上,collections模块还提供了几个额外的数据类型:namedtuple.deque.Counte ...

  4. python学习之老男孩python全栈第九期_day017知识点总结——初识递归、算法

    一. 递归函数 如果一个函数在内部调用自身本身,这个函数就是递归函数. 最大递归深度默认是997 -- python从内存角度出发做得限制(而不是程序真的报错),最大深度可以修改 def func(n ...

  5. python学习之老男孩python全栈第九期_day010知识点总结

    def qqxing(l = []): # 可变数据类型 l.append(1) print(l)qqxing() # [1]qqxing([]) # [1]qqxing() # [1, 1]qqxi ...

  6. python学习之老男孩python全栈第九期_day007知识点总结

    基础数据类型汇总 1. str 2. int 3. list 4. bool 5. dict (1) fromkeys Python 字典 fromkeys() 方法用于创建一个新的字典,并以可迭代对 ...

  7. python学习之老男孩python全栈第九期_day001知识点总结

    1. Python2与Python3的区别: Python2:源码不标准,混乱,重复代码太多: Python3:统一标准,去除重复代码. 编码方式: python2的默认编码方式为ASCII码:pyt ...

  8. python学习之老男孩python全栈第九期_day014知识点总结

    # 迭代器和生成器# 迭代器 # 双下方法:很少直接调用的方法,一般情况下,是通过其他语法触发的# 可迭代的 --> 可迭代协议:含有__iter__的方法( '__iter__' in dir ...

  9. python学习之老男孩python全栈第九期_day016知识点总结

    '''数据类型:intbool... 数据结构:dict (python独有的)listtuple (pytho独有的)setstr''' # reverse() 反转l = [1,2,3,4,5]l ...

随机推荐

  1. jQuery基础(1)

    一.jQuery的介绍 1.为什么要使用jQuery? 在用js写代码时,会遇到一些问题,如下: 1)window.onload 事件有事件覆盖的问题,因此只能写一个事件: 2)代码容错性差: 3)浏 ...

  2. One difference between AngularJS' $location and window.location

    Recenently, I encountered a problem. Client side code is: $http({ url: "/api/runtimelicense&quo ...

  3. IE不兼容document.getElementsByClassName

    在DOM3里已经加入了getElementsByClassName这个方法,然而IE9.10以外的其它版本均不支持,这是一块伤痛啊! 目前可以这么解决,判断浏览器支不支持这个方法,如果支持就不管:如果 ...

  4. vue中请求本地的json数据

    为什么要请求本地的数据?模拟后台的请求数据,验证页面的逻辑是否存在问题,抛开后台提前开发等. 常用的说来有:jq的方式 约等于 axios的方式,vuex状态管理的方式 个人认为最好用的就是jq的方式 ...

  5. 自然语言处理(英文演讲)_2-gram

    这里利用2-gram模型来提取一篇英文演讲的初略的主题句子,这里是英文演讲的的链接:http://pythonscraping.com/files/inaugurationSpeech.txt n-g ...

  6. 【原创】Jquery初体验二

    快速导航 一.传统方式生成Table 二.使用jquery.tmpl插件快速生成Table 三.Jquery中的操作class的几个方法 四:jq里面的克隆 五:属性过滤器 六:表单元素过滤器 一.传 ...

  7. Linux MBR扇区误删恢复

    目录 1. 引导记录误删恢复 1.1 备份引导记录 1.2 误删引导记录 1.3 恢复引导记录 2. 分区表误删恢复 2.1 备份分区表 2.2 误删分区表 2.3 恢复分区表 如果MBR分区表没了, ...

  8. java开发细节问题,spring的单例模式,多线程同步问题

    1.对象的赋值,new一个对象,然后在传递给函数赋值,往往这对对象赋值就可以使用了 2.对于 spring开发的细节问题 Spring框架里的bean,或者说组件,获取实例的时候都是默认的单例模式,这 ...

  9. Windows Mobile设备操作演示准备工作小记

    公司最近为PDA开发了一款作业程序,我在工作中常常需要将操作过程通过电脑上设影出来为客户讲解使用方法.本文记录了相关的准备工作. 1. 微软嵌入式操作系统体系 RTOS: Embedded Real ...

  10. SOA和微服务架构的区别?

    转自知乎:https://www.zhihu.com/question/37808426/answer/93335393 SOA和微服务架构的区别? 微服务架构强调的第一个重点就是业务系统需要彻底的组 ...