python学习笔记--运行时间装饰器cal_time自定义

在学习的时候发现直接调用装饰器可以很方便接入查询时间的函数

from cal_time import *

@cal_time
def quick_sort(li):
    """
        data 
    """

quick_sort(li)
# 这样就很方便

所以怎么才能使用装饰器呢

1.首先装饰器可以调用time函数,然后直接在方法上面加入@就行

import time
def show_time(func):
    def wrapper():
        star = time.process_time()
        func()
        end= time.process_time()
        print('spend_time:',end-star)
    return wrapper

@show_time
def func():
    print('test')

func()

这是一种方法调用可以使用show_time的装饰器进行修饰

2.其外还可以传入参数。直接传入wrapper当中。

import time
def show_time(func):
    def wrapper(a,b):
        star = time.process_time()
        func(a,b)
        end= time.process_time()
        print('spend_time:',end-star)
    return wrapper

@show_time
def add(a, b):
    print(a + b)
add(3,5)

这里可以想到,要是实际情况需要传入很多个参数,我手不得写麻,而且后期还不好维护,所以可以用python带的参数args,kwargs

import time
def show_time(func):
    def wrapper(*args, **kwargs):
        star = time.process_time()
        func(*args,**kwargs)
        end= time.process_time()
        print('spend_time:',end-star)
    return wrapper

@show_time
def add(*args, **kwargs):
    sum = 0
    for i in args:
        sum += i
    print(sum)
add(22,13,44,5,6,3,62)

其实就是把传入的参数改成args和kwargs两个可变参数。

这里有一个问题,当加入装饰器之后,函数的name,doc元信息都是消失啦,写的时候就会改变。

如上:

@show_time
def test():
    print("cake")
print(test.__name__)  # wrapper
def test2():
    print('cake2')
print(test2.__nmae__)  # test2

所以,python有一个方法functools的wraps,在方法上面加入@wraps(func) ,就可以复用当前的元信息

from functools import wraps
def show_time(func):
    @wraps(func)
    def wrapper():
        func()
    return wrapper

@show_time
def test():
    print('test_demo')

print(test.__name__)
def test1():
    print('test1_demo')

print(test1.__name__)

其中还可以在装饰器中传入参数,flag是True

import time
def cal_time(flag):

    def show_time(func):
        def wrapper(*args, **kwargs):
            star = time.process_time()
            func(*args, **kwargs)
            end = time.process_time()
            if flag == 'True':
                print('spend_time:',end-star)
        return wrapper
    return show_time

@cal_time("True")
def add(*args, **kwargs):
    sum = 0
    for i in args:
        sum += 1
    print(sum)
add(1,45,3,2,14)

甚至还有类装饰器,具有高灵活性、高内聚、封装性的特点。

import time
class Foo(object):
    def __init__(self, func):
        self.func = func

    def __call__(self):
        star = time.process_time()
        self.func()
        end = time.process_time()
        print('spend_time:', end-star)

@Foo
def bar():
    print('test')
bar()

类名Foo可以直接作为装饰器,用call调用。

当然还有内置的装饰器,晚点学习

@a
@b
@c
def f():

相当于 f = a(b(c(f)))

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python学习笔记》是由皮大庆编写的一本关于Python语言学习的教材。在这本书中,作者详细介绍了Python语言的基础知识、语法规则以及常用的编程技巧。 首先,作者简要介绍了Python语言的特点和优势。他提到,Python是一种易于学习和使用的编程语言,受到了广大程序员的喜爱。Python具有简洁、清晰的语法结构,使得代码可读性极高,同时也提供了丰富的库和模块,能够快速实现各种功能。 接着,作者详细讲解了Python的基本语法。他从变量、数据类型、运算符等基础知识开始,逐步介绍了条件语句、循环控制、函数、模块等高级概念。同时,作者通过大量的示例代码和实践案例,帮助读者加深对Python编程的理解和应用。 在书中,作者还特别强调了编写规范和良好的编程习惯。他从命名规范、注释风格、代码缩进等方面指导读者如何写出清晰、可读性强的Python代码。作者认为,良好的编程习惯对于提高代码质量和提高工作效率非常重要。 此外,作者还介绍了Python的常用库和模块。他提到了一些常用的库,如Numpy、Pandas、Matplotlib等。这些库在数据处理、科学计算、可视化等领域有广泛的应用,帮助读者更好地解决实际问题。 总的来说,《Python学习笔记》是一本非常实用和全面的Python学习教材。通过学习这本书,读者可以系统地学习和掌握Python编程的基础知识和高级应用技巧,为以后的编程学习和工作打下坚实的基础。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值