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

Joe*_*son 19 python time timezone pytz dst

我们有一台在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? 
Run Code Online (Sandbox Code Playgroud)

编辑:这是一段可行的代码片段.它不优雅,这就是为什么我要问是否有一个图书馆或为此而制作的东西.也许像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)
Run Code Online (Sandbox Code Playgroud)

Mat*_*int 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)
Run Code Online (Sandbox Code Playgroud)

用法:

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

>>> is_dst("America/Sao_Paulo")
True
Run Code Online (Sandbox Code Playgroud)

  • @JFSebastian - pytz docs明确指出需要使用`localize`; 将pytz时区传递给`datetime`的tzinfo参数是不够的.这是错的吗? (3认同)

jfs*_*jfs 11

from datetime import datetime
import pytz

isdst_now_in = lambda zonename: bool(datetime.now(pytz.timezone(zonename)).dst())
Run Code Online (Sandbox Code Playgroud)

例:

>>> 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
Run Code Online (Sandbox Code Playgroud)

这是Unix上使用time.tzset()函数的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
Run Code Online (Sandbox Code Playgroud)

用法是一样的:

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

注意:time.daylight由于某些边缘情况下的问题,未使用.