# 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. Mysql root账号general_log_file方法获取webshell

    在前面的phpmyadmin漏洞利用专题中介绍了如何通过root账号来获取webshell,但在现实情况中,由于Mysql版本较高以及配置文件的缘故,往往无法直接通过root账号写入网站真实路劲下获取 ...

  2. SpringCloud之Ribbon

    一:Ribbon是什么?  Ribbon是Netflix发布的开源项目,主要功能是提供客户端的软件负载均衡算法,将Netflix的中间层服务连接在一起.Ribbon客户端组件提供一系列完善的配置项如连 ...

  3. C#6.0语言规范(七) 表达式

    表达式是运算符和操作数的序列.本章定义了操作数和运算符的语法,求值顺序以及表达式的含义. 表达式分类 表达式分类为以下之一: 一个值.每个值都有一个关联的类型. 一个变量.每个变量都有一个关联的类型, ...

  4. elasticsearch5.6.3插件部署

    需要注意的是,5.x和2.x插件方面改动很大.参考:https://www.elastic.co/blog/running-site-plugins-with-elasticsearch-5-0.因为 ...

  5. Centos 7 快速搭建IOS可用IPsec

    安装 strongswan yum install -y http://ftp.nluug.nl/pub/os/Linux/distr/fedora-epel/7/x86_64/Packages/e/ ...

  6. (转) JVM Crash with SIGSEGV - problematic frame - libzip.so

    原文:https://stackoverflow.com/questions/38057362/jvm-crash-with-sigsegv-problematic-frame-libzip-so h ...

  7. vector源码(参考STL源码--侯捷):空间分配导致迭代器失效

    vector源码1(参考STL源码--侯捷) vector源码2(参考STL源码--侯捷) vector源码(参考STL源码--侯捷)-----空间分配导致迭代器失效 vector源码3(参考STL源 ...

  8. Azure Storage架构介绍

    Windows Azure Storage由三个重要部分或者说三种存储数据服务组成,它们是:Windows Azure Blob.Windows Azure Table和Windows Azure Q ...

  9. 源码分析篇 - Android绘制流程(三)requestLayout()与invalidate()流程及Choroegrapher类分析

    本文主要探讨能够触发performTraversals()执行的invalidate().postInvalidate()和requestLayout()方法的流程.在调用这三个方法到最后执行到per ...

  10. spring@Transactional注解事务不回滚不起作用无效的问题处理

    这几天在项目里面发现我使用@Transactional注解事务之后,抛了异常居然不回滚.后来终于找到了原因. 如果你也出现了这种情况,可以从下面开始排查. 一.特性先来了解一下@Transaction ...