8

I have two timestamps in miliseconds and i want to compute the difference between the two in minutes:

d1 = 1502053449617 

current_time_utc = int(round(time.time() * 1000))

The values for d1 are dynamically generated by a third party API and are in UTC . I am trying to get the difference between the current time in UTC and d1.

fmt = '%Y-%m-%d %H:%M:%S'

 time1  = datetime.strptime(d1, fmt)
 time2  = datetime.strptime(current_time_utc, fmt)

I want to be able to find the difference between the two (time1 - time2) . If i do the below , i get an error saying "string expected, long given"

print(    time1-time2)

I want the difference between the two in minutes . Please help

user1411837
  • 1,494
  • 6
  • 27
  • 41
  • 1
    Subtracting the two gives you the number of milliseconds. How many milliseconds are there in a minute? (Divide by 1000 to give the seconds, another 60 to give you minutes). – Mike Aug 10 '17 at 02:14

2 Answers2

18

You don't need to format the string, you just need to convert the timestamp directly, by first dividing it by 1000. Then its just a matter of printing out the differences (and calculating it in minutes):

from __future__ import division
import datetime

d1 = 1502053449617

converted_d1 = datetime.datetime.fromtimestamp(round(d1 / 1000))
current_time_utc = datetime.datetime.utcnow()

print((current_time_utc - converted_d1))
print((current_time_utc - converted_d1).total_seconds() / 60)

The above prints:

3 days, 5:08:14.087515
4628.234791916667
Burhan Khalid
  • 169,990
  • 18
  • 245
  • 284
9

I had to calculate the difference between two unix timestamps - but in days, as follows:

create two unix timestamps:

import datetime

timestamp1 = datetime.datetime(2017, 12, 1).strftime('%s')
timestamp2 = datetime.datetime(2017, 11, 14).strftime('%s')

print(timestamp1)
print(timestamp2)

1512079200
1510610400

calculate the day difference:

print((float(timestamp1)-float(timestamp2))/(60*60*24))

output:

17.0
Grant Shannon
  • 4,709
  • 1
  • 46
  • 36