使用Python查找当前是否在夏令时中的时区

时间:2013-11-04 18:39:42

标签: python time timezone dst pytz

我们有一台在GMT时间运行的服务器。我需要编写一个Python脚本来确定它是否是加利福尼亚州洛杉矶的当前(在此第二个)夏令时(DST)。我怎么能做到这一点?我看了一下pytz和时间,但我无法弄明白。我意识到我可以创建一些逻辑,例如比较LA中的当前时间和GMT时间,但如果我可以使用标准库,那将会更加清晰。

由于

编辑:以下是我设置时区的示例代码:

from pytz import timezone
import pytz
from datetime import datetime, timedelta

tz = timezone('America/Los_Angeles')
// Instantiate a datetime object using tz? 

编辑:这是一段可行的代码片段。它不优雅,这就是为什么我要问是否有一个图书馆或为此而制作的东西。也许就像一个is_dst()函数。

utc = timezone("UTC")
now = utc.localize(datetime.utcnow())
los_angeles_tz = timezone('America/Los_Angeles')
los_angeles_time = now.astimezone(los_angeles_tz)

delta = los_angeles_time.utcoffset()
dstDelta = timedelta(hours=-8)

is_dst = (delta == dstDelta)

2 个答案:

答案 0 :(得分:34)

import pytz
from datetime import datetime, timedelta

def is_dst(zonename):
    tz = pytz.timezone(zonename)
    now = pytz.utc.localize(datetime.utcnow())
    return now.astimezone(tz).dst() != timedelta(0)

用法:

>>> is_dst("America/Los_Angeles")
False

>>> is_dst("America/Sao_Paulo")
True

答案 1 :(得分:11)

from datetime import datetime
import pytz

isdst_now_in = lambda zonename: bool(datetime.now(pytz.timezone(zonename)).dst())

示例:

>>> isdst_now_in("America/Los_Angeles") # 2014-10-27 12:32:07 PDT-0700
True
>>> isdst_now_in("Australia/Melbourne") # 2014-10-28 06:32:07 AEDT+1100
True

这是使用time.tzset() function的Unix上的stdlib-only版本:

import os
import time
from contextlib import contextmanager

@contextmanager
def local_timezone(zonename):
    #NOTE: it manipulates global state
    oldname = os.environ.get('TZ')
    try:
        os.environ['TZ'] = zonename
        time.tzset()
        yield
    finally:
        if oldname is None:
           del os.environ['TZ']
        else:
           os.environ['TZ'] = oldname
        time.tzset()

def time_isdst_now_in(zonename):
    with local_timezone(zonename):
         return time.localtime().tm_isdst > 0

用法相同:

>>> time_isdst_now_in('Europe/London') # 2014-04-17 18:42:11 BST+0100
True

注意:由于issues in some edge cases而未使用time.daylight