>  기사  >  백엔드 개발  >  Python과 Django 간의 시간대 문제

Python과 Django 간의 시간대 문제

高洛峰
高洛峰원래의
2016-10-17 14:18:141254검색

코딩에서 시간 문제는 항상 시간대 문제로 헷갈리기 쉽습니다. 늘 시행착오를 거쳐 해결해 왔는데, 오늘 드디어 그 이유를 알아내고 마음속의 매듭을 풀었습니다. .

Python의 시간대 문제

datetime.today() / datetime.now()

이 두 함수는 현재 시스템 시간을 가져오지만, 가져온 datetime 객체는 tzinfo 시스템에 시간대가 설정되어 있어도 in은 비어 있습니다.

datetime.utcnow()

이 함수는 현재 UTC 시간을 가져오며, 이는 현재 시스템 시간과 시간대를 기준으로 계산되어야 합니다.

예를 들어 시스템 시간은 14:00, 시간대는 아시아/상하이(베이징 시간), utcnow 반환 시간은 6:00입니다. 마찬가지로 결과 객체의 tzinfo는 비어 있습니다.

환경 변수 TZ가 위 기능에 미치는 영향:

환경 변수 TZ가 시스템에 설정되거나 Python에 os.environ['TZ']가 설정된 경우 위의 함수에서 구한 시간은 해당 TZ 시간대의 시간입니다. 실제로 TZ는 이러한 기능이 아닌 시스템 시간에 영향을 미치는 것으로 볼 수 있는데, 이는 date 명령의 반환 결과를 보면 알 수 있다. datetime.now() 및 date 명령이 반환하는 결과는 항상 일관됩니다.

Django의 시간대 문제

위의 Python 함수를 이해하고 나면 Django의 시간대 문제는 간단해 보입니다.

django 설정에는 프로그램에서 사용하는 시간대를 설정하는 TIME_ZONE이라는 설정이 있습니다.

django 문서에서 TIME_ZONE의 기능은 os.environ['TZ']를 변경하는 것이지만 os.environ['TZ']를 변경해도 시스템 환경 변수 TZ는 변경되지 않습니다. , TIME_ZONE 설정이 시스템 시간대 설정과 일치하지 않으면 프로그램의 datetime.now()에서 얻은 시간이 date 명령의 시간과 일치하지 않습니다.

따라서 TIME_ZONE은 프로그램이 사용하려는 시간대로 설정되어야 합니다. 로컬 프로그램의 경우 TIME_ZONE을 시스템 시간대와 동일하게 설정할 수 있습니다. 국제 응용 프로그램의 경우 TIME_ZONE을 UTC로 설정한 다음 표시할 때 현재 사용자의 시간대에 따라 조정하는 것이 가장 좋습니다.

Manual

classmethod datetime.now([tz])

선택 인수 tz가 None이거나 지정되지 않은 경우 오늘과 같습니다. (), 그러나 가능하다면 time.time() 타임스탬프를 통해 얻을 수 있는 것보다 더 높은 정밀도를 제공합니다(예를 들어 C gettimeofday() 함수를 제공하는 플랫폼에서 가능할 수 있습니다).

그렇지 않으면 tz는 클래스 tzinfo 하위 클래스의 인스턴스여야 하며 현재 날짜와 시간은 tz의 시간대로 변환됩니다. 이 경우 결과는 tz.fromutc(datetime.utcnow().replace(tzinfo=tz )) 와 동일합니다. today(), utcnow()도 참조하세요.

classmethod datetime.utcnow()

tzinfo None을 사용하여 현재 UTC 날짜 및 시간을 반환합니다. 이는 now()와 같지만 반환합니다. 현재 UTC 날짜 및 시간(naivedatetime 객체) now()도 참조하세요.

시간대 변환 코드

import pytz
....
#dt the datetime var
dt.replace(tzinfo=pytz.utc).astimezone(pytz.timezone('Asia/Shanghai'))

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.