user1411837
user1411837

Reputation: 1564

python - Difference between two unix timestamps

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

Upvotes: 9

Views: 27234

Answers (2)

Grant Shannon
Grant Shannon

Reputation: 5055

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

Upvotes: 9

Burhan Khalid
Burhan Khalid

Reputation: 174624

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

Upvotes: 19

Related Questions