当前时区为 UTC + 8 小时



发表新帖 回复这个主题  [ 3 篇帖子 ] 
作者 内容
1 楼 
 文章标题 : 【Python3】使用AOP的方法,计算某某函数运行的时长
帖子发表于 : 2012-11-23 11:48 

注册: 2008-06-10 10:52
帖子: 49
送出感谢: 0 次
接收感谢: 0 次
使用timeit()函数,记录其他函数的运行时间。
代码:
#!/usr/bin/env python
# -*- coding:utf-8 -*-

from random import random
import time
import functools

def timeit(func):
    @functools.wraps(func)
    def wrapper(arg):
        st = time.time()
        func_re = func(arg)
        et = time.time()
        print('used:', et-st)
        return func_re
    return wrapper

@timeit
def foo(n):
    for x in range(n):
        pass
    return 'My name is foo()'.center(40, '-')

Re = foo(1000000)
print(Re)

代码:
运行结果:
used: 0.0625
------------My name is foo()------------

我的问题就是,当foo()函数的参数是未知的,或是一个递归函数,那timeit()函数就没有用了。
怎么打造一个万能的timeit函数啊!


页首
 用户资料  
 
2 楼 
 文章标题 : Re: 【Python3】使用AOP的方法,计算某某函数运行的时长
帖子发表于 : 2012-12-02 14:43 

注册: 2012-12-02 14:17
帖子: 2
系统: ubuntu12.04 LTS;win8
送出感谢: 0 次
接收感谢: 0 次
不会。。我才刚入门,都看不懂你的写的。。只是想问下@符号有什么用啊?难道是注解?


页首
 用户资料  
 
3 楼 
 文章标题 : Re: 【Python3】使用AOP的方法,计算某某函数运行的时长
帖子发表于 : 2012-12-02 16:24 
头像

注册: 2010-06-16 1:05
帖子: 14668
地址: Tencent
系统: Mac OS X
送出感谢: 1
接收感谢: 153
装饰器,面向切面编程


_________________
twitter求fo:http://twitter.com/maplebeats
博客求踩:http://maplebeats.com


页首
 用户资料  
 
显示帖子 :  排序  
发表新帖 回复这个主题  [ 3 篇帖子 ] 

当前时区为 UTC + 8 小时


在线用户

正在浏览此版面的用户:Yahoo [Bot], yq-ysy 和 0 位游客


不能 在这个版面发表主题
不能 在这个版面回复主题
不能 在这个版面编辑帖子
不能 在这个版面删除帖子
不能 在这个版面提交附件

前往 :  
本站点为公益性站点,用于推广开源自由软件,由 DiaHosting VPSBudgetVM VPS 提供服务。
我们认为:软件应可免费取得,软件工具在各种语言环境下皆可使用,且不会有任何功能上的差异;
人们应有定制和修改软件的自由,且方式不受限制,只要他们自认为合适。

Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group
简体中文语系由 王笑宇 翻译