ฉันจะบอกความแตกต่างของเวลาเป็นนาทีระหว่างสองdatetime
วัตถุได้อย่างไร
ฉันจะบอกความแตกต่างของเวลาเป็นนาทีระหว่างสองdatetime
วัตถุได้อย่างไร
คำตอบ:
>>> import datetime
>>> first_time = datetime.datetime.now()
>>> later_time = datetime.datetime.now()
>>> difference = later_time - first_time
>>> seconds_in_day = 24 * 60 * 60
datetime.timedelta(0, 8, 562000)
>>> divmod(difference.days * seconds_in_day + difference.seconds, 60)
(0, 8) # 0 minutes, 8 seconds
การลบในภายหลังจากครั้งแรกdifference = later_time - first_time
สร้างวัตถุ datetime ที่เก็บความแตกต่างเท่านั้น ในตัวอย่างข้างต้นคือ 0 นาที 8 วินาทีและ 562000 microseconds
delorean
แพ้ภัยdatetime
, pytz
วิธีการเช่นได้รับตัวอย่างรหัสเริ่มต้นอาจจะเขียนเป็นd = datetime.now(timezone(EST))
(บรรทัดที่อ่านได้อย่างใดอย่างหนึ่งแทนห้า)
ใหม่ที่งูหลาม 2.7 เป็นวิธีการเช่นtimedelta
จากเอกสารหลามนี้จะเทียบเท่ากับ.total_seconds()
(td.microseconds + (td.seconds + td.days * 24 * 3600) * 10**6) / 10**6
การอ้างอิง: http://docs.python.org/2/library/datetime.html#datetime.timedelta.total_seconds
>>> import datetime
>>> time1 = datetime.datetime.now()
>>> time2 = datetime.datetime.now() # waited a few minutes before pressing enter
>>> elapsedTime = time2 - time1
>>> elapsedTime
datetime.timedelta(0, 125, 749430)
>>> divmod(elapsedTime.total_seconds(), 60)
(2.0, 5.749430000000004) # divmod returns quotient and remainder
# 2 minutes, 5.74943 seconds
ใช้ตัวอย่างวันที่และเวลา
>>> from datetime import datetime
>>> then = datetime(2012, 3, 5, 23, 8, 15) # Random date in the past
>>> now = datetime.now() # Now
>>> duration = now - then # For build-in functions
>>> duration_in_s = duration.total_seconds() # Total number of seconds between dates
ระยะเวลาเป็นปี
>>> years = divmod(duration_in_s, 31536000)[0] # Seconds in a year=365*24*60*60 = 31536000.
ระยะเวลาเป็นวัน
>>> days = duration.days # Build-in datetime function
>>> days = divmod(duration_in_s, 86400)[0] # Seconds in a day = 86400
ระยะเวลาเป็นชั่วโมง
>>> hours = divmod(duration_in_s, 3600)[0] # Seconds in an hour = 3600
ระยะเวลาเป็นนาที
>>> minutes = divmod(duration_in_s, 60)[0] # Seconds in a minute = 60
ระยะเวลาเป็นวินาที
>>> seconds = duration.seconds # Build-in datetime function
>>> seconds = duration_in_s
ระยะเวลาเป็นไมโครวินาที
>>> microseconds = duration.microseconds # Build-in datetime function
ระยะเวลารวมระหว่างวันที่สองวัน
>>> days = divmod(duration_in_s, 86400) # Get days (without [0]!)
>>> hours = divmod(days[1], 3600) # Use remainder of days to calc hours
>>> minutes = divmod(hours[1], 60) # Use remainder of hours to calc minutes
>>> seconds = divmod(minutes[1], 1) # Use remainder of minutes to calc seconds
>>> print("Time between dates: %d days, %d hours, %d minutes and %d seconds" % (days[0], hours[0], minutes[0], seconds[0]))
หรือเพียงแค่:
>>> print(now - then)
แก้ไข 2019 เนื่องจากคำตอบนี้ได้รับแรงฉุดฉันจะเพิ่มฟังก์ชั่นซึ่งอาจทำให้การใช้งานง่ายขึ้นสำหรับบางคน
from datetime import datetime
def getDuration(then, now = datetime.now(), interval = "default"):
# Returns a duration as specified by variable interval
# Functions, except totalDuration, returns [quotient, remainder]
duration = now - then # For build-in functions
duration_in_s = duration.total_seconds()
def years():
return divmod(duration_in_s, 31536000) # Seconds in a year=31536000.
def days(seconds = None):
return divmod(seconds if seconds != None else duration_in_s, 86400) # Seconds in a day = 86400
def hours(seconds = None):
return divmod(seconds if seconds != None else duration_in_s, 3600) # Seconds in an hour = 3600
def minutes(seconds = None):
return divmod(seconds if seconds != None else duration_in_s, 60) # Seconds in a minute = 60
def seconds(seconds = None):
if seconds != None:
return divmod(seconds, 1)
return duration_in_s
def totalDuration():
y = years()
d = days(y[1]) # Use remainder to calculate next variable
h = hours(d[1])
m = minutes(h[1])
s = seconds(m[1])
return "Time between dates: {} years, {} days, {} hours, {} minutes and {} seconds".format(int(y[0]), int(d[0]), int(h[0]), int(m[0]), int(s[0]))
return {
'years': int(years()[0]),
'days': int(days()[0]),
'hours': int(hours()[0]),
'minutes': int(minutes()[0]),
'seconds': int(seconds()),
'default': totalDuration()
}[interval]
# Example usage
then = datetime(2012, 3, 5, 23, 8, 15)
now = datetime.now()
print(getDuration(then)) # E.g. Time between dates: 7 years, 208 days, 21 hours, 19 minutes and 15 seconds
print(getDuration(then, now, 'years')) # Prints duration in years
print(getDuration(then, now, 'days')) # days
print(getDuration(then, now, 'hours')) # hours
print(getDuration(then, now, 'minutes')) # minutes
print(getDuration(then, now, 'seconds')) # seconds
TypeError: 'float' object is not subscriptable
เมื่อใช้สำหรับ:then = datetime(2017, 8, 11, 15, 58, tzinfo=pytz.UTC)
now = datetime(2018, 8, 11, 15, 58, tzinfo=pytz.UTC)
getDuration(then, now, 'years')
เพียงลบจากอันอื่น คุณได้รับtimedelta
วัตถุที่มีความแตกต่าง
>>> import datetime
>>> d1 = datetime.datetime.now()
>>> d2 = datetime.datetime.now() # after a 5-second or so pause
>>> d2 - d1
datetime.timedelta(0, 5, 203000)
คุณสามารถแปลงdd.days
, dd.seconds
และdd.microseconds
นาที
ถ้าa
, b
เป็น datetime วัตถุแล้วเพื่อหาสิ่งที่แตกต่างของเวลาระหว่างพวกเขาในหลาม 3:
from datetime import timedelta
time_difference = a - b
time_difference_in_minutes = time_difference / timedelta(minutes=1)
ในเวอร์ชัน Python ก่อนหน้านี้:
time_difference_in_minutes = time_difference.total_seconds() / 60
ถ้าa
, b
มีวันที่และเวลาที่ไร้เดียงสาวัตถุดังกล่าวกลับมาเป็นตามdatetime.now()
นั้นผลที่อาจจะผิดถ้าวัตถุแทนเวลาท้องถิ่นที่แตกต่างกันกับ UTC ชดเชยเช่นการเปลี่ยนรอบเวลาหรือวันที่ผ่านมา / อนาคต รายละเอียดเพิ่มเติม: ค้นหาตลอด 24 ชั่วโมงหากมีการส่งผ่านระหว่าง datetimes - งูหลาม
ในการรับผลลัพธ์ที่เชื่อถือได้ให้ใช้เวลา UTC หรือวัตถุที่ทราบเวลาและเวลาของเขตเวลา
ใช้ divmod:
now = int(time.time()) # epoch seconds
then = now - 90000 # some time in the past
d = divmod(now-then,86400) # days
h = divmod(d[1],3600) # hours
m = divmod(h[1],60) # minutes
s = m[1] # seconds
print '%d days, %d hours, %d minutes, %d seconds' % (d[0],h[0],m[0],s)
นี่คือวิธีที่ฉันได้รับจำนวนชั่วโมงที่ผ่านไประหว่างสองวัตถุ datetime.datetime:
before = datetime.datetime.now()
after = datetime.datetime.now()
hours = math.floor(((after - before).seconds) / 3600)
timedelta.seconds
ให้จำนวนวินาทีที่เก็บไว้อย่างชัดเจนเท่านั้นซึ่งเอกสารรับประกันจะรวมน้อยกว่าหนึ่งวัน คุณต้องการ(after - before).total_seconds()
ซึ่งให้จำนวนวินาทีที่ครอบคลุมเดลต้าทั้งหมด
(after - before).total_seconds() // 3600
(Python 2.7) หรือ(after - before) // timedelta(seconds=3600)
(Python 3)
หากต้องการค้นหาจำนวนวัน: timedelta มีแอตทริบิวต์ 'วัน' คุณสามารถค้นหาได้ง่ายๆ
>>>from datetime import datetime, timedelta
>>>d1 = datetime(2015, 9, 12, 13, 9, 45)
>>>d2 = datetime(2015, 8, 29, 21, 10, 12)
>>>d3 = d1- d2
>>>print d3
13 days, 15:59:33
>>>print d3.days
13
แค่คิดว่ามันอาจมีประโยชน์ที่จะพูดถึงการจัดรูปแบบเช่นกันเกี่ยวกับ timedelta strptime () แยกวิเคราะห์สตริงที่แสดงเวลาตามรูปแบบ
from datetime import datetime
datetimeFormat = '%Y/%m/%d %H:%M:%S.%f'
time1 = '2016/03/16 10:01:28.585'
time2 = '2016/03/16 09:56:28.067'
time_dif = datetime.strptime(time1, datetimeFormat) - datetime.strptime(time2,datetimeFormat)
print(time_dif)
ผลลัพธ์นี้: 0: 05: 00.518000
ฉันใช้ somethign เช่นนี้:
from datetime import datetime
def check_time_difference(t1: datetime, t2: datetime):
t1_date = datetime(
t1.year,
t1.month,
t1.day,
t1.hour,
t1.minute,
t1.second)
t2_date = datetime(
t2.year,
t2.month,
t2.day,
t2.hour,
t2.minute,
t2.second)
t_elapsed = t1_date - t2_date
return t_elapsed
# usage
f = "%Y-%m-%d %H:%M:%S+01:00"
t1 = datetime.strptime("2018-03-07 22:56:57+01:00", f)
t2 = datetime.strptime("2018-03-07 22:48:05+01:00", f)
elapsed_time = check_time_difference(t1, t2)
print(elapsed_time)
#return : 0:08:52
return t1-t2
นี่คือการค้นหาความแตกต่างระหว่างเวลาปัจจุบันและ 9.30 น
t=datetime.now()-datetime.now().replace(hour=9,minute=30)
from datetime import datetime, timedelta
from time import mktime
yesterday = datetime.now() - timedelta(days=1)
today = datetime.now()
difference_in_seconds = abs(mktime(yesterday.timetuple()) - mktime(today.timetuple()))
difference_in_minutes = difference_in_seconds / 60
mktime()
คาดว่าเวลาท้องถิ่นเป็นอินพุต เวลาท้องถิ่นอาจจะคลุมเครือและmktime()
อาจตอบกลับผิดในกรณีนี้ ใช้a - b
แทน (A, B - วัตถุ datetime) mktime()
ไม่จำเป็นและบางครั้งก็ผิด อย่าใช้มันในกรณีนี้
ในวิธีอื่นเพื่อรับความแตกต่างระหว่างวันที่;
import dateutil.parser
import datetime
last_sent_date = "" # date string
timeDifference = current_date - dateutil.parser.parse(last_sent_date)
time_difference_in_minutes = (int(timeDifference.days) * 24 * 60) + int((timeDifference.seconds) / 60)
รับเอาท์พุทเป็นมิน
ขอบคุณ
ฉันใช้ความแตกต่างของเวลาสำหรับการทดสอบการรวมอย่างต่อเนื่องเพื่อตรวจสอบและปรับปรุงการทำงานของฉัน นี่คือรหัสง่ายๆถ้ามีคนต้องการมัน
from datetime import datetime
class TimeLogger:
time_cursor = None
def pin_time(self):
global time_cursor
time_cursor = datetime.now()
def log(self, text=None) -> float:
global time_cursor
if not time_cursor:
time_cursor = datetime.now()
now = datetime.now()
t_delta = now - time_cursor
seconds = t_delta.total_seconds()
result = str(now) + ' tl -----------> %.5f' % seconds
if text:
result += " " + text
print(result)
self.pin_time()
return seconds
time_logger = TimeLogger()
โดยใช้:
from .tests_time_logger import time_logger
class Tests(TestCase):
def test_workflow(self):
time_logger.pin_time()
... my functions here ...
time_logger.log()
... other function(s) ...
time_logger.log(text='Tests finished')
และฉันมีบางอย่างเช่นนั้นในบันทึกผลลัพธ์
2019-12-20 17:19:23.635297 tl -----------> 0.00007
2019-12-20 17:19:28.147656 tl -----------> 4.51234 Tests finished
จาก @Attaque คำตอบที่ดีฉันขอเสนอเครื่องคำนวณความแตกต่างของวันที่และเวลาที่สั้นลง:
seconds_mapping = {
'y': 31536000,
'm': 2628002.88, # this is approximate, 365 / 12; use with caution
'w': 604800,
'd': 86400,
'h': 3600,
'min': 60,
's': 1,
'mil': 0.001,
}
def get_duration(d1, d2, interval, with_reminder=False):
if with_reminder:
return divmod((d2 - d1).total_seconds(), seconds_mapping[interval])
else:
return (d2 - d1).total_seconds() / seconds_mapping[interval]
ฉันได้เปลี่ยนมันเพื่อหลีกเลี่ยงการประกาศฟังก์ชั่นซ้ำ ๆ ลบช่วงเวลาเริ่มต้นการพิมพ์ที่สวยและเพิ่มการสนับสนุนสำหรับมิลลิวินาทีสัปดาห์และเดือน ISO (เดือนในใจเป็นเพียงประมาณโดยประมาณขึ้นอยู่กับสมมติฐานว่าแต่ละเดือนมีค่าเท่ากับ365/12
)
ซึ่งผลิต:
d1 = datetime(2011, 3, 1, 1, 1, 1, 1000)
d2 = datetime(2011, 4, 1, 1, 1, 1, 2500)
print(get_duration(d1, d2, 'y', True)) # => (0.0, 2678400.0015)
print(get_duration(d1, d2, 'm', True)) # => (1.0, 50397.12149999989)
print(get_duration(d1, d2, 'w', True)) # => (4.0, 259200.00149999978)
print(get_duration(d1, d2, 'd', True)) # => (31.0, 0.0014999997802078724)
print(get_duration(d1, d2, 'h', True)) # => (744.0, 0.0014999997802078724)
print(get_duration(d1, d2, 'min', True)) # => (44640.0, 0.0014999997802078724)
print(get_duration(d1, d2, 's', True)) # => (2678400.0, 0.0014999997802078724)
print(get_duration(d1, d2, 'mil', True)) # => (2678400001.0, 0.0004999997244524721)
print(get_duration(d1, d2, 'y', False)) # => 0.08493150689687975
print(get_duration(d1, d2, 'm', False)) # => 1.019176965856293
print(get_duration(d1, d2, 'w', False)) # => 4.428571431051587
print(get_duration(d1, d2, 'd', False)) # => 31.00000001736111
print(get_duration(d1, d2, 'h', False)) # => 744.0000004166666
print(get_duration(d1, d2, 'min', False)) # => 44640.000024999994
print(get_duration(d1, d2, 's', False)) # => 2678400.0015
print(get_duration(d1, d2, 'mil', False)) # => 2678400001.4999995