算法 - 如何使用python計算2個毫秒級字符串的計算
問題描述
比如從源頭數據可以獲得2個時間,其形式為'2017-03-09 08:51:51 615''2017-03-09 08:52:21 601'要計算前后者的時間差
自己百度搜索了很多相關內容,都無法解決這個問題,datetime不知道如何轉換毫秒,timedelta無法轉換年份因為業務的精度要求,不能省略后面的毫秒,要計算兩者的時間差。當然基本上都是同一天,但考慮到業務是24小時進行的,也不能忽略前面的日期,萬一問題正好發生在0點前后呢
問題解答
回答1:datetime可以轉換毫秒的啊,精度都達到微秒了?;蛘哒f我沒理解清楚問題?比如可以使用格式符%f,如下所示:
>>> t1 = '2017-03-09 08:51:51 615'>>> t2 = '2017-03-09 08:52:21 601'>>> from datetime import datetime>>> a = datetime.strptime(t1, '%Y-%m-%d %H:%M:%S %f')>>> b = datetime.strptime(t2, '%Y-%m-%d %H:%M:%S %f')>>> c = b - a>>> cdatetime.timedelta(0, 29, 986000)>>> c.microseconds986000
這里c中第三個是微秒。
回答2:2017-03-09 08:51:51轉成時間戳然后字符串連接'615',就是毫秒精度的時間戳了、兩個時間戳數值還算不出來嗎?
回答3:時間戳是以秒為單位,所以乘以1000就是毫秒,微秒除以1000也是毫秒
# coding: utf-8from datetime import datetimeimport timeformat = ’%Y-%m-%d %H:%M:%S %f’a = datetime.strptime('2017-03-09 08:51:51 615', format)b = datetime.strptime('2017-03-09 08:52:21 601', format)t1 = time.mktime(a.timetuple()) * 1000 + a.microsecond / 1000t2 = time.mktime(b.timetuple()) * 1000 + b.microsecond / 1000print t2 - t1
相關文章:
1. 老師您的微信號是多少?2. javascript - 微信網頁開發從菜單進入頁面后,按返回鍵沒有關閉瀏覽器而是刷新當前頁面,求解決?3. node.js - nodejs開發中常用的連接mysql的庫4. 在html文件的目錄下輸入代碼按回車后顯示這個,哪位大佬幫幫我 呀5. mysql - jdbc的問題6. mysql replace 死鎖7. 視頻文件不能播放,怎么辦?8. mysql - 分庫分表、分區、讀寫分離 這些都是用在什么場景下 ,會帶來哪些效率或者其他方面的好處9. windows7 ping不通虛擬機VMware上的linux(ubuntu)的ip10. mysql - 如何減少使用或者不用LEFT JOIN查詢?
