python 获取毫秒级时间问题的解决

 更新时间:2021年04月09日 11:05:12   作者:正一番薯  
这篇文章主要介绍了python 获取毫秒级时间问题的解决,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

根据网上的一些说法,

在python里获取ms级系统时间可以通过以下方式获取:

import datetime
print(datetime.datetime.now().microsecond)

但通过以下代码测试,发现返回的并不是ms的值,而是us的值:

import datetime 
def getTime_ms():
    return (datetime.datetime.now().hour*3600 +\
            datetime.datetime.now().minute*60+\
            datetime.datetime.now().second )*1000+\
           datetime.datetime.now().microsecond/1000
 
def timetime():
    t = getTime_ms()
    while getTime_ms() - t < 500:
        pass
    a = getTime_ms()
    print(t, a, a- t) 
  
if __name__ == '__main__': 
    from timeit import timeit
    t = timeit('timetime()', 'from __main__ import timetime', number=1)
    print(t)

打印结果

(35460614, 35461114, 500) 0.499531984329

上面实验不太直观,换一个直观点的:

def timetime():
    t1 = datetime.datetime.now()
    while 1:
        t2 = datetime.datetime.now()
        if (t2 - t1).microseconds >= 1:
            print(t2,t2.microsecond,t1,t1.microsecond,(t2-t1).seconds)
            break 
 
if __name__ == '__main__':
    from timeit import timeit
    t = timeit('timetime()', 'from __main__ import timetime', number=1)
    print(t)
    #print (datetime.datetime.now())

输出

(datetime.datetime(2019, 4, 3, 10, 6, 20, 461882), 461882, datetime.datetime(2019, 4, 3, 10, 6, 20, 461863), 461863, 0) 7.10487365723e-05

def timetime():
    t1 = datetime.datetime.now()
    while 1:
        t2 = datetime.datetime.now()
        if (t2 - t1).microseconds >= 1000:
            print(t2,t2.microsecond,t1,t1.microsecond,(t2-t1).seconds)
            break 
 
if __name__ == '__main__':
    from timeit import timeit
    t = timeit('timetime()', 'from __main__ import timetime', number=1)
    print(t)
    #print (datetime.datetime.now())

输出

(datetime.datetime(2019, 4, 3, 10, 13, 52, 76548), 76548, datetime.datetime(2019, 4, 3, 10, 13, 52, 75547), 75547, 0) 0.00104904174805

补充:Python datetime去除毫秒 返回当前时间

datetime模块返回当前时间

import datetime
if __name__ == '__main__':
    a = datetime.datetime.now().replace(microsecond=0)
    print(a, type(a))

运算结果:

2020-05-22 12:13:42 <class 'datetime.datetime'> Process finished with exit code 0

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。

相关文章

  • 使用PIL(Python-Imaging)反转图像的颜色方法

    使用PIL(Python-Imaging)反转图像的颜色方法

    今天小编就为大家分享一篇使用PIL(Python-Imaging)反转图像的颜色方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-01-01
  • Python并发多线程的具体操作步骤

    Python并发多线程的具体操作步骤

    并发指的是任务数多余cpu核数,通过操作系统的各种任务调度算法,实现用多任务一起执行,下面这篇文章主要给大家介绍了关于Python并发多线程的具体操作步骤的相关资料,需要的朋友可以参考下
    2024-02-02
  • python实现支持目录FTP上传下载文件的方法

    python实现支持目录FTP上传下载文件的方法

    这篇文章主要介绍了python实现支持目录FTP上传下载文件的方法,适用于windows及Linux平台FTP传输文件及文件夹,需要的朋友可以参考下
    2015-06-06
  • python嵌套字典比较值与取值的实现示例

    python嵌套字典比较值与取值的实现示例

    这篇文章主要给大家介绍了关于python嵌套字典比较值与取值的实现方法,详细介绍了python字典嵌套字典的情况下获取某个key的value的相关内容,分享出来供大家参考学习,需要的朋友们下面来一起看看吧。
    2017-11-11
  • 基于PyQt5实现SqlServer数据库表导出Excel表格小工具

    基于PyQt5实现SqlServer数据库表导出Excel表格小工具

    这篇文章主要为大家详细介绍了PyQt5的应用案例之实现SqlServer数据库表导出Excel表格小工具,文中的示例代码讲解详细,需要的小伙伴可以参考一下
    2023-12-12
  • Python List计算列表平方的9种常见方法

    Python List计算列表平方的9种常见方法

    平方操作是指将一个数值乘以自身,即计算数值的平方,这篇文章主要给大家介绍了关于Python List计算列表平方的9种常见方法,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-03-03
  • Python打印斐波拉契数列实例

    Python打印斐波拉契数列实例

    这篇文章主要介绍了Python打印斐波拉契数列的方法,实例分析了基于Python实现斐波那契数列的实现技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-07-07
  • 如何利用Boost.Python实现Python C/C++混合编程详解

    如何利用Boost.Python实现Python C/C++混合编程详解

    这篇文章主要给大家介绍了关于如何利用Boost.Python实现Python C/C++混合编程的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起看看吧
    2018-11-11
  • 浅析Django接口版本控制

    浅析Django接口版本控制

    一个项目在升级迭代的时候,不会立马抛弃旧的版本,甚至会出现多个版本共存同时维护的情况,因此需要版本控制
    2021-06-06
  • python实现自动发送邮件发送多人、群发、多附件的示例

    python实现自动发送邮件发送多人、群发、多附件的示例

    下面小编就为大家分享一篇python实现自动发送邮件发送多人、群发、多附件的示例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-01-01

最新评论