Programing

현지 시간 문자열을 UTC로 변환하는 방법?

lottogame 2020. 3. 23. 08:01
반응형

현지 시간 문자열을 UTC로 변환하는 방법?


현지 시간 의 날짜 시간 문자열을 UTC 시간문자열 로 어떻게 변환 합니까?

나는 이것을 전에 한 적이 있다고 확신하지만 그것을 찾을 수 없으므로 SO는 저 (그리고 다른 사람들)가 미래에 그렇게하도록 희망적으로 도울 것입니다.

설명 : 예를 들어 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 시간.


먼저 문자열을 순진한 datetime 객체로 구문 분석하십시오. datetime.datetime시간대 정보가 첨부되지 않은 인스턴스입니다 . datetime.strptime날짜 문자열 구문 분석 대한 정보는 문서를 참조하십시오 .

pytz표준 시간대 + UTC와 함께 제공 되는 모듈을 사용하십시오 . 현지 시간대가 무엇인지 파악하고 그로부터 시간대 개체를 생성 한 후 순진한 날짜 시간을 조작하고 첨부하십시오.

마지막으로, datetime.astimezone()메소드를 사용 하여 날짜 시간을 UTC로 변환하십시오.

"2001-2-3 10:11:12"문자열에 대해 현지 시간대 "America / Los_Angeles"를 사용하는 소스 코드 :

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")

datetime 모듈의 utcnow () 함수를 사용하여 현재 UTC 시간을 얻을 수 있습니다.

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

Tom이 위에서 언급 한 링크 : http://lucumr.pocoo.org/2011/7/15/eppur-si-muove/ 는 말합니다 :

UTC는 일광 절약 시간 제가없는 시간대이며 여전히 구성 변경이없는 시간대입니다.

항상 UTC로 시간을 측정하고 저장하십시오 .

시간이 걸린 곳을 기록해야 할 경우에는 별도로 보관하십시오. 현지 시간 + 시간대 정보를 저장 하지 마십시오 !

참고 -데이터가 DST를 사용하는 지역에있는 경우 pytzJohn Millikin의 답변을 사용하십시오.

주어진 문자열에서 UTC 시간을 얻고 DST를 사용하지 않는 세계의 지역에있을만큼 운이 좋거나 DST를 적용하지 않고 UTC에서만 오프셋 된 데이터가있는 경우 :

-> 오프셋 시간의 기준으로 현지 시간 사용 :

>>> # 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'

최신 정보:

파이썬 3.2부터 datetime.timezone사용 가능합니다. 아래 명령을 사용하여 시간대 인식 날짜 시간 객체를 생성 할 수 있습니다.

import datetime

timezone_aware_dt = datetime.datetime.now(datetime.timezone.utc)

시간대 변환을 할 준비가 되었다면 다음을 읽으십시오.

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


@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-> 튜플 (시간대가 적용되지 않으므로 문자열과 일치)

time.mktime
현지 시간 튜플-에포크 이후 초 (항상 현지 시간)

time.gmtime
epoch 이후의 초-> UTC

calendar.timegm
에포크 이후 UTC-> 초 단위로 튜플

time.localtime
시대 이후 초-> 현지 시간대의 튜플


일반적인 파이썬 시간 변환에 대한 요약은 다음과 같습니다.

일부 방법은 몇 초 만에 삭제되며 (s) 로 표시됩니다 . ts = (d - epoch) / unit대신 jfs 덕분에 명시 적 수식을 사용할 수 있습니다.

  • struct_time (UTC) → POSIX (s) :
    calendar.timegm(struct_time)
  • 나이브 날짜 시간 (로컬) → POSIX (s) :
    calendar.timegm(stz.localize(dt, is_dst=None).utctimetuple())
    (DST 전환 중 예외, jfs의 설명 참조)
  • 나이브 날짜 시간 (UTC) → POSIX (s) :
    calendar.timegm(dt.utctimetuple())
  • 인식 날짜 시간 → POSIX (s) :
    calendar.timegm(dt.utctimetuple())
  • POSIX → struct_time (UTC, s ) :
    time.gmtime(t)
    (jfs의 주석 참조)
  • 나이브 날짜 시간 (로컬) → struct_time (UTC, s ) :
    stz.localize(dt, is_dst=None).utctimetuple()
    (DST 전환 중 예외, jfs의 설명 참조)
  • 나이브 날짜 시간 (UTC) → struct_time (UTC, s ) :
    dt.utctimetuple()
  • 인식 날짜 시간 → struct_time (UTC, s ) :
    dt.utctimetuple()
  • POSIX → Naïve 날짜 시간 (현지) :
    datetime.fromtimestamp(t, None)
    (특정 조건에서 실패 할 수 있습니다 . 아래 jfs의 주석 참조)
  • struct_time (UTC) → Naive 날짜 시간 (local, s ) :
    datetime.datetime(struct_time[:6], tzinfo=UTC).astimezone(tz).replace(tzinfo=None)
    (윤초를 나타낼 수 없음, jfs의 설명 참조)
  • 나이브 날짜 시간 (UTC) → 나이브 날짜 시간 (현지) :
    dt.replace(tzinfo=UTC).astimezone(tz).replace(tzinfo=None)
  • 날짜 시간 인식 → 나이브 날짜 시간 (현지) :
    dt.astimezone(tz).replace(tzinfo=None)
  • POSIX → 나이브 날짜 시간 (UTC) :
    datetime.utcfromtimestamp(t)
  • struct_time (UTC) → Naive 날짜 시간 (UTC, s ) :
    datetime.datetime(*struct_time[:6])
    (윤초를 나타낼 수 없음, jfs의 주석 참조)
  • 나이브 날짜 시간 (로컬) → 나이브 날짜 시간 (UTC) :
    stz.localize(dt, is_dst=None).astimezone(UTC).replace(tzinfo=None)
    (DST 전환 중 예외, jfs의 설명 참조)
  • 날짜 시간 인식 → 나이브 날짜 시간 (UTC) :
    dt.astimezone(UTC).replace(tzinfo=None)
  • POSIX → 인식 날짜 시간 :
    datetime.fromtimestamp(t, tz)
    (pytz가 아닌 시간대의 경우 실패 할 수 있음)
  • struct_time (UTC) → Aware datetime (s) :
    datetime.datetime(struct_time[:6], tzinfo=UTC).astimezone(tz)
    (윤초를 나타낼 수 없음, jfs의 주석 참조)
  • 나이브 날짜 시간 (로컬) → 인식 날짜 시간 :
    stz.localize(dt, is_dst=None)
    (DST 전환 중 예외, jfs의 설명 참조)
  • 나이브 날짜 시간 (UTC) → 인식 날짜 시간 :
    dt.replace(tzinfo=UTC)

출처 : taaviburns.ca


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())

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')

(이 응답에서 UTC 날짜 시간 문자열을 로컬 날짜 시간 으로 변환 하기 위해 코드가 파생되었습니다 )


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'

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

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'

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")

당신은 그것을 할 수 있습니다 :

>>> from time import strftime, gmtime, localtime
>>> strftime('%H:%M:%S', gmtime()) #UTC time
>>> strftime('%H:%M:%S', localtime()) # localtime

단순한

나는 이렇게했다 :

>>> 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

멋진 구현

화려하고 싶다면 이것을 functor로 바꿀 수 있습니다.

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

어때요-

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

초이면 None로컬 시간을 UTC 시간으로 변환하고 그렇지 않으면 전달 된 시간을 UTC로 변환합니다.


일광 절약 시간제 등을 돌아 다니는 경우

위의 답변 중 어느 것도 특히 나를 도왔습니다. 아래 코드는 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>)

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') 

이 라이브러리는 인생을 쉽게 만듭니다 :)


python3에서 :

pip install python-dateutil

from dateutil.parser import tz

mydt.astimezone(tz.gettz('UTC')).replace(tzinfo=None) 

나는 또 다른 질문에 대한 최선의 답을 찾을 여기를 . 파이썬 내장 라이브러리 만 사용하고 현지 시간대를 입력 할 필요가 없습니다 (필자의 경우 요구 사항)

import time
import calendar

local_time = time.strptime("2018-12-13T09:32:00.000", "%Y-%m-%dT%H:%M:%S.%f")
local_seconds = time.mktime(local_time)
utc_time = time.gmtime(local_seconds)

이 질문은 검색 키워드에 따라 연결된 질문 대신 Google에 표시되므로 답변을 다시 게시하고 있습니다.


이 경우 ... pytz는 최고의 lib입니다

import pytz
utc = pytz.utc
yourdate = datetime.datetime.now()
yourdateutc = yourdate.astimezone(utc).replace(tzinfo=None)

참고 URL : https://stackoverflow.com/questions/79797/how-to-convert-local-time-string-to-utc

반응형