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

作者:正一番薯 时间:2022-01-06 15:27:30 

根据网上的一些说法,

在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

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

来源:https://blog.csdn.net/weixin_41698305/article/details/88988481

标签:python,毫秒级,时间
0
投稿

猜你喜欢

  • pandas的apply函数用法详解

    2022-05-09 11:41:16
  • Python通过wordcloud库实现将单词生成词云

    2022-02-24 20:17:18
  • 浅谈Python如何获取excel数据

    2021-04-06 09:30:32
  • Vue Socket.io源码解读

    2024-06-05 15:28:35
  • 对python中的six.moves模块的下载函数urlretrieve详解

    2023-10-20 00:23:45
  • vue项目中使用axios遇到的相对路径和绝对路径问题

    2024-05-13 09:37:40
  • 详解使用pymysql在python中对mysql的增删改查操作(综合)

    2024-01-14 00:17:13
  • Java 数据库连接池c3p0 介绍

    2024-01-22 02:44:24
  • python 字典 setdefault()和get()方法比较详解

    2022-12-11 01:28:41
  • JavaScript判断变量是否为undefined的两种写法区别

    2024-04-19 09:53:50
  • Pandas 稀疏数据结构的实现

    2022-01-29 15:08:32
  • python ip正则式

    2022-02-13 22:13:02
  • python tkinter界面居中显示的方法

    2023-10-14 11:16:18
  • JS如何实现form表单登录验证并使用MD5加密详解

    2024-04-10 10:38:56
  • ubuntu kylin 14.10下多个mysql 5.7.14安装教程

    2024-01-24 12:50:13
  • 使用python实现http及ftp服务进行数据传输的方法

    2021-08-26 01:20:19
  • 如何编写一个高效的国税系统通讯录数据库?

    2009-11-07 18:53:00
  • python实现m3u8格式转换为mp4视频格式

    2021-05-09 00:48:02
  • MySQL大库搭建主从的一种思路分享

    2024-01-21 22:53:34
  • Python执行Linux系统命令的4种方法

    2023-08-10 19:04:50
  • asp之家 网络编程 m.aspxhome.com