Вопрос:

Как преобразовать локальное время в UTC в Python?

python datetime utc

292073 просмотра

17 ответа

17684 Репутация автора

Как преобразовать строку datetime в локальное время в строку в UTC ?

Я уверен, что я сделал это раньше, но не могу найти его, и я надеюсь, что это поможет мне (и другим) сделать это в будущем.

Разъяснение : Например, если у меня есть 2008-09-17 14:02:00в моей временной зоне ( +10), я хотел бы создать строку с эквивалентным UTCвременем: 2008-09-17 04:02:00.

Кроме того, из http://lucumr.pocoo.org/2011/7/15/eppur-si-muove/ , обратите внимание, что в целом это невозможно, так как при использовании DST и других вопросов нет уникального преобразования из местного времени в Время UTC.

Автор: Tom Источник Размещён: 17.09.2008 03:52

Ответы (17)


22 плюса

13146 Репутация автора

def local_to_utc(t):
    secs = time.mktime(t)
    return time.gmtime(secs)

def utc_to_local(t):
    secs = calendar.timegm(t)
    return time.localtime(secs)

Источник: http://feihonghsu.blogspot.com/2008/02/converting-from-local-time-to-utc.html

Пример использования из bd808 : если ваш источник является datetime.datetimeобъектом t, вызовите его как:

local_to_utc(t.timetuple())
Автор: Chuck Callebs Размещён: 17.09.2008 03:54

207 плюса

153346 Репутация автора

Сначала проанализируйте строку в наивный объект datetime. Это пример datetime.datetimeбез информации о часовом поясе. См. Документацию для datetime.strptimeполучения информации о разборе строки даты.

Используйте pytzмодуль, который поставляется с полным списком часовых поясов + UTC. Выясните, что такое местный часовой пояс, постройте из него объект часовой пояс и манипулируйте и присоедините его к наивному дат-времени.

Наконец, используйте datetime.astimezone()метод для преобразования даты и времени в UTC.

Исходный код с использованием локального часового пояса «America / Los_Angeles» для строки «2001-2-3 10:11:12»:

import pytz, datetime
local = pytz.timezone ("America/Los_Angeles")
naive = datetime.datetime.strptime ("2001-2-3 10:11:12", "%Y-%m-%d %H:%M:%S")
local_dt = local.localize(naive, is_dst=None)
utc_dt = local_dt.astimezone(pytz.utc)

Оттуда вы можете использовать strftime()метод для форматирования даты и времени UTC по мере необходимости:

utc_dt.strftime ("%Y-%m-%d %H:%M:%S")
Автор: John Millikin Размещён: 17.09.2008 04:07

58 плюса

17684 Репутация автора

Решение

Благодаря @rofly полное преобразование из строки в строку выглядит следующим образом:

time.strftime("%Y-%m-%d %H:%M:%S", 
              time.gmtime(time.mktime(time.strptime("2008-09-17 14:04:00", 
                                                    "%Y-%m-%d %H:%M:%S"))))

Мое резюме функций time/ calendar:

time.strptime
string -> tuple (не применяется часовой пояс, поэтому соответствует строке)

time.mktime
местный кортеж времени -> секунды с эпохи (всегда локальное время)

time.gmtime
секунд с эпохи -> кортеж в UTC

а также

calendar.timegm
кортеж в UTC -> секунды с эпохи

time.localtime
секунд с эпохи -> кортеж в локальном часовом поясе

Автор: Tom Размещён: 17.09.2008 04:15

2 плюса

0 Репутация автора

Как насчет -

time.strftime("%Y-%m-%dT%H:%M:%SZ", time.gmtime(seconds))

если секунды, Noneто он преобразует местное время в UTC, время еще преобразует прошедшее время в UTC.

Автор: Anonymous fool Размещён: 23.09.2009 06:28

107 плюса

25126 Репутация автора

Функция utcnow () модуля datetime может использоваться для получения текущего времени UTC.

>>> import datetime
>>> utc_datetime = datetime.datetime.utcnow()
>>> utc_datetime.strftime("%Y-%m-%d %H:%M:%S")
'2010-02-01 06:59:19'

Как упоминалось выше, Том: http://lucumr.pocoo.org/2011/7/15/eppur-si-muove/ говорит:

UTC - это часовой пояс без летнего времени и по-прежнему часовой пояс без изменений конфигурации в прошлом.

Всегда измеряйте и сохраняйте время в UTC .

Если вам нужно записать, где было время, сохраните это отдельно. Не сохраняйте местное время + информацию о часовом поясе!

ПРИМЕЧАНИЕ. Если какая-либо из ваших данных находится в регионе, который использует DST, используйте pytzи взгляните на ответ Джона Милликина.

Если вы хотите получить время UTC из данной строки, и вам повезло оказаться в регионе мира, который либо не использует DST, либо у вас есть данные, которые только смещены от UTC без применения DST:

-> используя локальное время в качестве основы для значения смещения:

>>> # Obtain the UTC Offset for the current system:
>>> UTC_OFFSET_TIMEDELTA = datetime.datetime.utcnow() - datetime.datetime.now()
>>> local_datetime = datetime.datetime.strptime("2008-09-17 14:04:00", "%Y-%m-%d %H:%M:%S")
>>> result_utc_datetime = local_datetime + UTC_OFFSET_TIMEDELTA
>>> result_utc_datetime.strftime("%Y-%m-%d %H:%M:%S")
'2008-09-17 04:04:00'

-> Или из известного смещения, используя datetime.timedelta ():

>>> UTC_OFFSET = 10
>>> result_utc_datetime = local_datetime - datetime.timedelta(hours=UTC_OFFSET)
>>> result_utc_datetime.strftime("%Y-%m-%d %H:%M:%S")
'2008-09-17 04:04:00'

Если вы готовы принять переходы по часовому поясу, прочитайте следующее:

https://medium.com/@eleroy/10-things-you-need-to-know-about-date-and-time-in-python-with-datetime-pytz-dateutil-timedelta-309bfbafb3f7

Автор: monkut Размещён: 01.02.2010 07:00

6 плюса

61 Репутация автора

если вы предпочитаете datetime.datetime:

dt = datetime.strptime("2008-09-17 14:04:00","%Y-%m-%d %H:%M:%S")
utc_struct_time = time.gmtime(time.mktime(dt.timetuple()))
utc_dt = datetime.fromtimestamp(time.mktime(utc_struct_time))
print dt.strftime("%Y-%m-%d %H:%M:%S")
Автор: user235042 Размещён: 27.02.2010 04:12

0 плюса

3497 Репутация автора

в этом случае ... pytz is best lib

import pytz
utc = pytz.utc
yourdate = datetime.datetime.now()
yourdateutc = yourdate.astimezone(utc).replace(tzinfo=None)
Автор: Mohammad Efazati Размещён: 06.11.2010 04:02

7 плюса

79 Репутация автора

import time

import datetime

def Local2UTC(LocalTime):

    EpochSecond = time.mktime(LocalTime.timetuple())
    utcTime = datetime.datetime.utcfromtimestamp(EpochSecond)

    return utcTime

>>> LocalTime = datetime.datetime.now()

>>> UTCTime = Local2UTC(LocalTime)

>>> LocalTime.ctime()

'Thu Feb  3 22:33:46 2011'

>>> UTCTime.ctime()

'Fri Feb  4 05:33:46 2011'
Автор: Scipythonee Размещён: 04.02.2011 05:38

2 плюса

137 Репутация автора

Для получения дневного света и т. Д.

Ни один из вышеперечисленных ответов не помог мне. Следующий код работает для GMT.

def get_utc_from_local(date_time, local_tz=None):
    assert date_time.__class__.__name__ == 'datetime'
    if local_tz is None:
        local_tz = pytz.timezone(settings.TIME_ZONE) # Django eg, "Europe/London"
    local_time = local_tz.normalize(local_tz.localize(date_time))
    return local_time.astimezone(pytz.utc)

import pytz
from datetime import datetime

summer_11_am = datetime(2011, 7, 1, 11)
get_utc_from_local(summer_11_am)
>>>datetime.datetime(2011, 7, 1, 10, 0, tzinfo=<UTC>)

winter_11_am = datetime(2011, 11, 11, 11)
get_utc_from_local(winter_11_am)
>>>datetime.datetime(2011, 11, 11, 11, 0, tzinfo=<UTC>)
Автор: Dantalion Размещён: 09.11.2011 04:59

16 плюса

69844 Репутация автора

Мне повезло с dateutil (что широко рекомендуется для SO по другим связанным вопросам):

from datetime import *
from dateutil import *
from dateutil.tz import *

# METHOD 1: Hardcode zones:
utc_zone = tz.gettz('UTC')
local_zone = tz.gettz('America/Chicago')
# METHOD 2: Auto-detect zones:
utc_zone = tz.tzutc()
local_zone = tz.tzlocal()

# Convert time string to datetime
local_time = datetime.strptime("2008-09-17 14:02:00", '%Y-%m-%d %H:%M:%S')

# Tell the datetime object that it's in local time zone since 
# datetime objects are 'naive' by default
local_time = local_time.replace(tzinfo=local_zone)
# Convert time to UTC
utc_time = local_time.astimezone(utc_zone)
# Generate UTC time string
utc_string = utc_time.strftime('%Y-%m-%d %H:%M:%S')

(Код был получен из этого ответа, чтобы преобразовать строку datetime UTC в локальное datetime )

Автор: Yarin Размещён: 19.12.2011 02:58

17 плюса

179 Репутация автора

Еще один пример с pytz, но включает localize (), который спас мой день.

import pytz, datetime
utc = pytz.utc
fmt = '%Y-%m-%d %H:%M:%S'
amsterdam = pytz.timezone('Europe/Amsterdam')

dt = datetime.datetime.strptime("2012-04-06 10:00:00", fmt)
am_dt = amsterdam.localize(dt)
print am_dt.astimezone(utc).strftime(fmt)
'2012-04-06 08:00:00'
Автор: Paulius Sladkevičius Размещён: 06.04.2012 07:54

3 плюса

69 Репутация автора

Вы можете сделать это с помощью:

>>> from time import strftime, gmtime, localtime
>>> strftime('%H:%M:%S', gmtime()) #UTC time
>>> strftime('%H:%M:%S', localtime()) # localtime
Автор: Cristian Salamea Размещён: 21.08.2012 04:30

13 плюса

1214 Репутация автора

Я добился наибольшего успеха в python-dateutil :

from dateutil import tz

def datetime_to_utc(date):
    """Returns date in UTC w/o tzinfo"""
    return date.astimezone(tz.gettz('UTC')).replace(tzinfo=None) if date.tzinfo else date
Автор: Shu Wu Размещён: 29.08.2012 09:40

27 плюса

19911 Репутация автора

Вот краткое изложение общих преобразований времени Python.

Некоторые методы снижают доли секунд и помечены (-ы) . Явная формула, например, ts = (d - epoch) / unitможет использоваться вместо (спасибо jfs).

  • struct_time (UTC) → POSIX (s) :
    calendar.timegm(struct_time)
  • Наивное datetime (локальное) → POSIX (s) :
    calendar.timegm(stz.localize(dt, is_dst=None).utctimetuple())
    (исключение при переходе DST, см. Комментарий от jfs)
  • Наивное datetime (UTC) → POSIX (s) :
    calendar.timegm(dt.utctimetuple())
  • Aware datetime → POSIX (ы) :
    calendar.timegm(dt.utctimetuple())
  • POSIX → struct_time (UTC, s ):
    time.gmtime(t)
    (см. Комментарий от jfs)
  • Наивное datetime (локальное) → struct_time (UTC, s ):
    stz.localize(dt, is_dst=None).utctimetuple()
    (исключение при переходах DST, см. Комментарий от jfs)
  • Наивное datetime (UTC) → struct_time (UTC, s ):
    dt.utctimetuple()
  • Aware datetime → struct_time (UTC, s ):
    dt.utctimetuple()
  • POSIX → Наивное datetime (локальное):
    datetime.fromtimestamp(t, None)
    (может не работать в определенных условиях, см. Комментарий от jfs ниже)
  • struct_time (UTC) → Naïve datetime (local, s ):
    datetime.datetime(struct_time[:6], tzinfo=UTC).astimezone(tz).replace(tzinfo=None)
    (не может представлять секунды прыжка, см. комментарий от jfs)
  • Наивное datetime (UTC) → Наивное datetime (местное):
    dt.replace(tzinfo=UTC).astimezone(tz).replace(tzinfo=None)
  • Aware datetime → Наивное datetime (локальное):
    dt.astimezone(tz).replace(tzinfo=None)
  • POSIX → Naïve datetime (UTC):
    datetime.utcfromtimestamp(t)
  • struct_time (UTC) → Naïve datetime (UTC, s ):
    datetime.datetime(*struct_time[:6])
    (не может представлять секунды прыжка, см. комментарий от jfs)
  • Наивное datetime (локальное) → Наивное datetime (UTC):
    stz.localize(dt, is_dst=None).astimezone(UTC).replace(tzinfo=None)
    (исключение при переходах DST, см. Комментарий от jfs)
  • Aware datetime → Naïve datetime (UTC):
    dt.astimezone(UTC).replace(tzinfo=None)
  • POSIX → Aware datetime:
    datetime.fromtimestamp(t, tz)
    (может не работать для не-pytz timezones)
  • struct_time (UTC) → Aware datetime (s) :
    datetime.datetime(struct_time[:6], tzinfo=UTC).astimezone(tz)
    (не может представлять секунды прыжка, см. комментарий от jfs)
  • Наивное datetime (локальное) → Aware datetime:
    stz.localize(dt, is_dst=None)
    (исключение при переходе DST, см. Комментарий от jfs)
  • Наивное datetime (UTC) → Aware datetime:
    dt.replace(tzinfo=UTC)

Источник: taaviburns.ca

Автор: akaihola Размещён: 26.10.2012 09:38

2 плюса

2564 Репутация автора

Использование http://crsmithdev.com/arrow/

arrowObj = arrow.Arrow.strptime('2017-02-20 10:00:00', '%Y-%m-%d %H:%M:%S' , 'US/Eastern')

arrowObj.to('UTC') or arrowObj.to('local') 

Эта библиотека облегчает жизнь :)

Автор: Yash Размещён: 20.02.2017 03:32

1 плюс

403 Репутация автора

В python3:

pip install python-dateutil

from dateutil.parser import tz

mydt.astimezone(tz.gettz('UTC')).replace(tzinfo=None) 
Автор: spedy Размещён: 11.01.2018 09:03

2 плюса

136 Репутация автора

просто

Я сделал это так:

>>> utc_delta = datetime.utcnow()-datetime.now()
>>> utc_time = datetime(2008, 9, 17, 14, 2, 0) + utc_delta
>>> print(utc_time)
2008-09-17 19:01:59.999996

Причудливая реализация

Если вы хотите получить фантазию, вы можете превратить это в функтора:

class to_utc():
    utc_delta = datetime.utcnow() - datetime.now()

    def __call__(cls, t):
        return t + cls.utc_delta

Результат:

>>> utc_converter = to_utc()
>>> print(utc_converter(datetime(2008, 9, 17, 14, 2, 0)))
2008-09-17 19:01:59.999996
Автор: uclatommy Размещён: 02.05.2018 03:50
Вопросы из категории :
32x32