您好,登录后才能下订单哦!
Python中time库如何使用,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
clock的实现因平台而异,使用getclockinfo可以当前clock实现的基本信息,包括clock的精度。
def clock_basic():
    import textwrap
    available_clocks = [
        ('time', time.time),
        ('monotonic', time.monotonic),
        ('perf_counter', time.perf_counter),
        ('process_time', time.process_time),
    ]
    for clock_name, func in available_clocks:
        print (
            textwrap.dedent('''
            {name}:
                adjustable    :{info.adjustable}
                implementation:{info.implementation}
                monotonic     :{info.monotonic}
                resolution    :{info.resolution}
                current       :{current}'''.format(name=clock_name, info=time.get_clock_info(clock_name), current=func())
            )
        )time模块的核心函数之一是time(),将epoch开始后的秒数作为浮点数返回。opoch作为时间测量的开始,对于Unix系统而言是:1970年1月1日的0:00,尽管该值是浮点数,实际精度取决于平台。对于时间的存储或者比较,浮点数表示很方便,但是可读性较差,因此对于日志或者打印时间,ctime()方法更有用。
def clock_time():
    print (time.time())
    print (time.ctime())用户或者系统服务为了跨机器同步时钟,会修改系统时钟,time()方法查看的是系统时钟,因此多次调用time()方法,可能会产生向前或者向后的值。当使用这些值进行计算或者试图测量连续时间时,会产生意外行为。monotonic()方法,可以避免这种情况,因为只返回向前的值。
def clock_monotonic():
    start = time.monotonic()
    time.sleep(0.1)
    end = time.monotonic()
    print (start)
    print (end)monotonic时钟的开始时间为定义,返回值只能用于与其他时钟值的计算。
process_time()返回是处理器时钟时间:表示处理器真实的执行时间,因此当程序没有做任何事情的时候,处理器时钟并不会增加。
def processor_clock():
    template = '{} - {:.2f} - {:.2f}'
    print (template.format(time.ctime(), time.time(), time.process_time()))
    for i in range(3, 0, -1):
        time.sleep(i)
        print (template.format(time.ctime(), time.time(), time.process_time()))高精度的单调时钟对于性能测量非常重要,最佳时钟数据源的确定依赖相关的平台信息,Python在perf_counter中提供了。
def perf_counter_clock():
    loop_start = time.perf_counter()
    for i in range(5):
        iter_start = time.perf_counter()
        a = 1
        for i in range(10000):
            a = a + i
        now = time.perf_counter()
        loop_elapsed = now - loop_start
        iter_elapsed = now - iter_start
        print ('{:.6f} {:.6f}'.format(loop_elapsed, iter_elapsed))看完上述内容,你们掌握Python中time库如何使用的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。