Преобразование строки временной метки unix в удобочитаемую дату

У меня есть строка, представляющая временную метку unix (т.е. "1284101485" ) в Python, и я хотел бы преобразовать ее в читаемую дату. Когда я использую time.strftime, я получаю TypeError:

>>>import time
>>>print time.strftime("%B %d %Y", "1284101485")

Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: argument must be 9-item sequence, not str

Ответ 1

Используйте модуль datetime:

from datetime import datetime
ts = int("1284101485")

# if you encounter a "year is out of range" error the timestamp
# may be in milliseconds, try 'ts /= 1000' in that case
print(datetime.utcfromtimestamp(ts).strftime('%Y-%m-%d %H:%M:%S'))

Ответ 2

>>> from datetime import datetime
>>> datetime.fromtimestamp(1172969203.1)
datetime.datetime(2007, 3, 4, 0, 46, 43, 100000)

Взято из http://seehuhn.de/pages/pdate

Ответ 3

Самый проголосовавший ответ предлагает использовать fromtimestamp, который подвержен ошибкам, поскольку он использует локальный часовой пояс. Чтобы избежать проблем, лучше использовать UTC:

datetime.datetime.utcfromtimestamp(posix_time).strftime('%Y-%m-%dT%H:%M:%SZ')

Где posix_time - это эпоха Posix, которую вы хотите преобразовать

Ответ 4

>>> import time
>>> time.ctime(int("1284101485"))
'Fri Sep 10 16:51:25 2010'
>>> time.strftime("%D %H:%M", time.localtime(int("1284101485")))
'09/10/10 16:51'

Ответ 5

Есть две части:

  • Преобразовать временную метку unix ( "секунды с эпохи" ) в локальное время
  • Отобразить местное время в нужном формате.

Портативный способ получить локальное время, которое работает, даже если локальный часовой пояс имел другое смещение utc в прошлом, и python не имеет доступа к базе данных tz, это использовать часовой пояс pytz:

#!/usr/bin/env python
from datetime import datetime
import tzlocal  # $ pip install tzlocal

unix_timestamp = float("1284101485")
local_timezone = tzlocal.get_localzone() # get pytz timezone
local_time = datetime.fromtimestamp(unix_timestamp, local_timezone)

Чтобы отобразить его, вы можете использовать любой формат времени, поддерживаемый вашей системой, например:

print(local_time.strftime("%Y-%m-%d %H:%M:%S.%f%z (%Z)"))
print(local_time.strftime("%B %d %Y"))  # print date in your format

Если вам не нужно локальное время, чтобы получить читаемое время UTC:

utc_time = datetime.utcfromtimestamp(unix_timestamp)
print(utc_time.strftime("%Y-%m-%d %H:%M:%S.%f+00:00 (UTC)"))

Если вам не нужны проблемы с часовым поясом, которые могут повлиять на дату возврата или если у python есть доступ к базе данных tz в вашей системе:

local_time = datetime.fromtimestamp(unix_timestamp)
print(local_time.strftime("%Y-%m-%d %H:%M:%S.%f"))

В Python 3 вы можете получить дату и время, относящиеся к часовому поясу, используя только stdlib (смещение UTC может быть неправильным, если у python нет доступа к базе данных tz в вашей системе, например, в Windows):

#!/usr/bin/env python3
from datetime import datetime, timezone

utc_time = datetime.fromtimestamp(unix_timestamp, timezone.utc)
local_time = utc_time.astimezone()
print(local_time.strftime("%Y-%m-%d %H:%M:%S.%f%z (%Z)"))

Функции модуля time представляют собой тонкие обертки вокруг соответствующего API-интерфейса C, поэтому они могут быть менее переносимыми, чем соответствующие методы datetime, иначе вы могли бы их использовать:

#!/usr/bin/env python
import time

unix_timestamp  = int("1284101485")
utc_time = time.gmtime(unix_timestamp)
local_time = time.localtime(unix_timestamp)
print(time.strftime("%Y-%m-%d %H:%M:%S", local_time)) 
print(time.strftime("%Y-%m-%d %H:%M:%S+00:00 (UTC)", utc_time))  

Ответ 6

Для удобной для пользователя метки времени из отметки времени UNIX, я использовал это в сценариях до:

import os, datetime

datetime.datetime.fromtimestamp(float(os.path.getmtime("FILE"))).strftime("%B %d, %Y")

Вывод:

'26 декабря 2012 г.

Ответ 7

Вы можете преобразовать текущее время, подобное этому

t=datetime.fromtimestamp(time.time())
t.strftime('%Y-%m-%d')
'2012-03-07'

Чтобы преобразовать дату в строку в разные форматы.

import datetime,time

def createDateObject(str_date,strFormat="%Y-%m-%d"):    
    timeStamp = time.mktime(time.strptime(str_date,strFormat))
    return datetime.datetime.fromtimestamp(timeStamp)

def FormatDate(objectDate,strFormat="%Y-%m-%d"):
    return objectDate.strftime(strFormat)

Usage
=====
o=createDateObject('2013-03-03')
print FormatDate(o,'%d-%m-%Y')

Output 03-03-2013

Ответ 8

Помимо использования пакета time/datetime, pandas также может использоваться для решения одной и той же проблемы. Вот как мы можем использовать pandas, чтобы преобразовать временную метку в читаемую дату:

Временные метки могут быть в двух форматах:

  • 13 цифр (миллисекунды) - Чтобы преобразовать миллисекунды на сегодняшний день, используйте:

    import pandas
    result_ms=pandas.to_datetime('1493530261000',unit='ms')
    str(result_ms)
    
    Output: '2017-04-30 05:31:01'
    
  • 10 цифр (в секундах) - Чтобы преобразовать секунды на сегодняшний день, используйте:

    import pandas
    result_s=pandas.to_datetime('1493530261',unit='s')
    str(result_s)
    
    Output: '2017-04-30 05:31:01'
    

Ответ 9

timestamp ="124542124"
value = datetime.datetime.fromtimestamp(timestamp)
exct_time = value.strftime('%d %B %Y %H:%M:%S')

Получите читаемую дату из отметки времени вместе со временем, также вы можете изменить формат даты.

Ответ 10

import datetime
temp = datetime.datetime.fromtimestamp(1386181800).strftime('%Y-%m-%d %H:%M:%S')
print temp

Ответ 11

Я только что успешно использовал:

>>> type(tstamp)
pandas.tslib.Timestamp
>>> newDt = tstamp.date()
>>> type(newDt)
datetime.date

Ответ 12

быстрый и грязный один вкладыш:

'-'.join(str(x) for x in list(tuple(datetime.datetime.now().timetuple())[:6]))

'2013-5-5-1-9-43'

Ответ 13

Другой способ сделать это можно с помощью функции gmtime и format;

from time import gmtime
print('{}-{}-{} {}:{}:{}'.format(*gmtime(1538654264.703337)))

Выход: 2018-10-4 11:57:44

Ответ 14

Вы можете использовать easy_date, чтобы упростить его:

import date_converter
my_date_string = date_converter.timestamp_to_string(1284101485, "%B %d, %Y")

Ответ 15

Существует интересный способ, при котором вам не нужно беспокоиться о часовых поясах, utc и т.д. Просто преобразуйте строку в формат даты Excel, а затем в удобочитаемую дату/время:

import datetime

def xldate_to_datetime(xldate):
    temp = datetime.datetime(1899, 12, 30)
    delta = datetime.timedelta(days=xldate)
    return temp+delta

ts = "1284101485"
tsxl = ((int(ts)/60)/60)/24 + 25569
readabledate =  xldate_to_datetime(tsxl)
print(readabledate)

Ответ 16

Вы посмотрели пакет datetime? Я считаю, что у него есть метод fromUnixTimestamp.