- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我在夏令时方面遇到问题。
让我解释一下上下文。
我将 UTC 日期存储在我的数据库中。每个用户都有一个时区,我也将此信息存储在数据库中。
我根据每个用户的时区计算“1 个月”的时间段。
例如,用户应该看到:
2014-01-06 -> 2014-02-05
2014-02-06 -> 2014-03-05
2014-03-06 -> 2014-04-05
2014-04-06 -> 2014-05-05
2014-05-06 -> 2014-06-05
etc.
夏令时开启或关闭(3 月和 11 月)时出现问题
代替:
2014-03-06 -> 2014-04-05
,我得到 2014-03-06 -> 2014-04-06
2014-11-06 -> 2014-12-05
,我得到 2014-11-05 -> 2014-12-04
然后它会为所有下一个偏移。
我尝试使用 UTC 日期而不是将它们转换为用户时区以在 get_end_date 中添加 1 个月,但我仍然遇到问题。
知道如何处理这个吗?
谢谢
这是我的代码和 get_end_date 方法。
import pytz
from dateutil.parser import parse as parse_date
from dateutil.relativedelta import relativedelta
def to_tz(dt, tz):
tz = pytz.timezone(tz)
return tz.normalize(dt.astimezone(tz))
def get_end_date(dt, tz):
dt_central = to_tz(dt, tz)
# Add 1 month, set hours, minutes, seconds, microseconds to 0 and remove -1 ms
dt_central = dt_central + relativedelta(months=+1)
dt_central = dt_central.replace(hour=0, minute=0, second=0, microsecond=0)
dt_central = dt_central + relativedelta(microseconds=-1)
return to_tz(dt_central, 'UTC')
def print_periods(start_dt, tz, nb_periods=6):
for i in xrange(nb_periods):
print '\n# Period {}'.format(i+1)
end_dt = get_end_date(start_dt, tz)
start_dt_central, end_dt_central = to_tz(start_dt, tz), to_tz(end_dt, tz)
print '{} -> {}'.format(start_dt_central.date(), end_dt_central.date())
print ' > start_dt_central: ', start_dt_central
print ' > end_dt_central: ', end_dt_central
print ' > start_dt: ', start_dt
print ' > end_dt: ', end_dt
start_dt = end_dt + relativedelta(microseconds=1)
输出:
central_tz = 'US/Central'
start_dt = parse_date('2014-01-06 06:00:00+00:00')
In [7]: print_periods(start_dt, central_tz, nb_periods=12)
# Period 1
2014-01-06 -> 2014-02-05
> start_dt_central: 2014-01-06 00:00:00-06:00
> end_dt_central: 2014-02-05 23:59:59.999999-06:00
# Period 2
2014-02-06 -> 2014-03-05
> start_dt_central: 2014-02-06 00:00:00-06:00
> end_dt_central: 2014-03-05 23:59:59.999999-06:00
# Period 3
2014-03-06 -> 2014-04-06
> start_dt_central: 2014-03-06 00:00:00-06:00
> end_dt_central: 2014-04-06 00:59:59.999999-05:00
# Period 4
2014-04-06 -> 2014-05-05
> start_dt_central: 2014-04-06 01:00:00-05:00
> end_dt_central: 2014-05-05 23:59:59.999999-05:00
# Period 5
2014-05-06 -> 2014-06-05
> start_dt_central: 2014-05-06 00:00:00-05:00
> end_dt_central: 2014-06-05 23:59:59.999999-05:00
# Period 6
2014-06-06 -> 2014-07-05
> start_dt_central: 2014-06-06 00:00:00-05:00
> end_dt_central: 2014-07-05 23:59:59.999999-05:00
# Period 7
2014-07-06 -> 2014-08-05
> start_dt_central: 2014-07-06 00:00:00-05:00
> end_dt_central: 2014-08-05 23:59:59.999999-05:00
# Period 8
2014-08-06 -> 2014-09-05
> start_dt_central: 2014-08-06 00:00:00-05:00
> end_dt_central: 2014-09-05 23:59:59.999999-05:00
# Period 9
2014-09-06 -> 2014-10-05
> start_dt_central: 2014-09-06 00:00:00-05:00
> end_dt_central: 2014-10-05 23:59:59.999999-05:00
# Period 10
2014-10-06 -> 2014-11-05
> start_dt_central: 2014-10-06 00:00:00-05:00
> end_dt_central: 2014-11-05 22:59:59.999999-06:00
# Period 11
2014-11-05 -> 2014-12-04
> start_dt_central: 2014-11-05 23:00:00-06:00
> end_dt_central: 2014-12-04 23:59:59.999999-06:00
# Period 12
2014-12-05 -> 2015-01-04
> start_dt_central: 2014-12-05 00:00:00-06:00
> end_dt_central: 2015-01-04 23:59:59.999999-06:00
Christian 的解决方案 1
def get_end_date(dt, tz):
dt_central = to_tz(dt, tz)
orig_tz = dt_central.tzinfo
dt_central = dt_central.replace(tzinfo=None)
# Calculations
dt_central = orig_tz.localize(dt_central)
dt_utc = to_tz(dt_central, 'UTC')
return dt_utc
我自己的解决方案2
def get_end_date(dt, tz):
dt_central = to_tz(dt, tz)
# Calculations
dt_utc = to_tz(dt_central, 'UTC')
# When switch to Daylight Saving Time
if to_tz(dt_utc, tz).hour == 0:
dt_utc = dt_utc.replace(hour=dt_utc.hour-1)
# When leave Daylight Saving Time
elif to_tz(dt_utc, tz).hour == 22:
dt_utc = dt_utc.replace(hour=dt_utc.hour+1)
return dt_utc
最佳答案
我在扩展 vevents 的重复规则时遇到了与 dateutil 的 rrule
类似的问题。对我有用的是保存时区信息,然后将每个日期时间对象转换为原始日期时间对象,进行计算,然后使用保存的时区本地化每个日期时间。
所以按照这些思路:
orig_tz = dt.tzinfo
dt = dt.replace(tzinfo=None)
# do calculations here
orig_tz.localize(dt)
关于python夏令时问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25715276/
举个例子,让我们使用以下 cron 表达式:“0 0 14 1 * ?” -> 在每月第一天的 14:00 触发。 我使用 Quartz CronScheduleBuilder 来构建表达式,但这无关
由于某种原因,夏令时开始时,我的一个网站在午夜 12:00 自动发布,从晚上 11:00 开始发布。有什么方法可以设置 MySQL 服务器变量以正确处理夏令时更改吗? 最佳答案 请提供... SHOW
如何检查夏令时是否生效? 最佳答案 您可以使用time.localtime并查看返回值中的 tm_isdst 标志。 >>> import time >>> time.localtime() (201
我有一个奇怪的问题: 我从 mysql 数据库中获取一些数据,我将这些数据用 strotime 转换为时间戳。然后我将这些时间戳与 for 循环进行比较: for ($i=$start;$imodif
如何检查夏令时是否有效? 最佳答案 您可以使用 time.localtime并查看返回值中的 tm_isdst 标志。 >>> import time >>> time.localtime() (20
我使用以下代码在文件中生成日期: echo "DTSTART;TZID=" . date_default_timezone_get() . ":" . strftime('%Y%m%d', strto
在下面,为什么 to_char() 中不包含夏令时?我怎样才能获得夏令时的时间? SELECT systimestamp AT TIME ZONE 'Australia/Adelaide' from
以下是连续两天之间的小时数计算: (AbsoluteTime[{2011, 3, 14}] - AbsoluteTime[{2011, 3, 13}]) / 3600 因此,您可能不会对 Mathem
function DateTimeToFileTime(FileTime: TDateTime): TFileTime; var LocalFileTime, Ft: TFileTime; S
我制作了一个小代码片段。告诉你几岁,精确到秒。 但是我发现了一些奇怪的事情。我知道时间和时区是工作的噩梦,但这是在我自己的国家和时区内,所以我有点困惑。 如果我输入日期。 27-12-2013(dd-
在 Jenkins 的夜间构建中,我们的一项测试在凌晨 2:00:12 失败。经过一段时间的调试和更改计算机的系统时间后,我感到非常困惑。然后我写了下面的测试(模拟问题),它失败了,但我不明白为什么。
linux如何处理夏令时(DST) 切换是否立即发生,例如 3 点钟立即切换到 2 点钟?或者变化缓慢我问你这个是因为我的服务器上有很大的日期基础,如果这个切换在数据库中的条目上立即发生一小时,将会
我正在使用 NSDate 格式化程序从 Facebook Graph API 请求(格林威治标准时间)获取日期并将其转换为用户的本地时区。我可以很好地读取日期并设置它的新时区,但是当我打印出新日期时,
我的 API 使用 ISO 8601 向客户端表示时间。我们有一个功能,我们希望显示它来自哪个时区。通过纯粹存储时区偏移,我们正在失去对细节的跟踪。 即,犹他州和亚利桑那州遵守 MST -06:00半
PHP代码 $t = strtotime( '2012-09-21T03:00:00+00:00 America/Chicago' ); $t2 = date('c',$t); echo $t2;
PHP代码 $t = strtotime( '2012-09-21T03:00:00+00:00 America/Chicago' ); $t2 = date('c',$t); echo $t2;
我有这个问题。我有这个格式的日期 var datestring = "2017-10-30T15:03:10.933044Z"; 如果我这样写代码 var d = new Date(datestrin
每当日光切换发生时,我都会触发事件。 我知道何时会发生 Spring /秋季切换 TimeZone.CurrentTimeZone.GetDaylightChanges(year) 这会返回 2 个日
我正在开发一个关心夏令时变化的关键应用程序。 我试图通过比较跨越夏令时变化的日期来手动模拟运行时可能发生的情况,因此我进行了以下测试。我当前所在的位置是意大利,因此今年从 CEST(中欧夏令时)更改为
我有这个应用程序,它将当前日期与来自 xml 文件的已解析日期进行比较: Date timeDiff = new Date(date.getTime() - new Date().getTime())
我是一名优秀的程序员,十分优秀!