[Zope-dev] DateTime issues with negative offsets
Juan A. Diaz
nueces at ravvit.net
Fri Dec 7 19:22:54 UTC 2012
Hi all,
I found a issue with the DateTime module. For what I could see the
functions _tzoffset2rfc822zone and _tzoffset2iso8601zone, that are
used to return a zone specification, have problems with negative
offset. This not happens with all the negative offset, just when the
hour is not rounded and have minutes.
Functions '_tzoffset2rfc822zone' and '_tzoffset2iso8601zonethat' are
used in the mtehods 'DateTime.ISO8601' and 'DateTime.rfc822'.
I think it may be clearer with some examples:
>>> dt = DateTime('2004/06/14 14:30:15 GMT+0430')
>>> dt.rfc822()
'Mon, 14 Jun 2004 14:30:15 +0430'
>>> dt.ISO8601()
'2004-06-14T14:30:15+04:30'
This is Ok.
>>> dt = DateTime('2004/06/14 14:30:15 GMT-0400')
>>> dt.rfc822()
'Mon, 14 Jun 2004 14:30:15 -0400'
>>> dt.ISO8601()
'2004-06-14T14:30:15-04:00'
This is Ok.
>>> dt = DateTime('2004/06/14 14:30:15 GMT-0430')
>>> dt.rfc822()
'Mon, 14 Jun 2004 14:30:15 -0530'
>>> dt.ISO8601()
'2004-06-14T14:30:15-05:30'
This is not. As you could see, the offset printed is -0530.
This is the code for both functions
def _tzoffset2rfc822zone(seconds):
"""Takes an offset, such as from _tzoffset(), and returns an
rfc822
compliant zone specification. Please note that the result of
_tzoffset() is the negative of what time.localzone and time.altzone is.
"""
return "%+03d%02d" % divmod((seconds / 60), 60)
def _tzoffset2iso8601zone(seconds):
"""Takes an offset, such as from _tzoffset(), and returns an ISO 8601
compliant zone specification. Please note that the result of
_tzoffset() is the negative of what time.localzone and time.altzone is.
"""
return "%+03d:%02d" % divmod((seconds / 60), 60)
I think that the error come from the way in where the integer division works.
>>> secconds = (4 * 60 + 30) * 60
>>> secconds
16200
>>> divmod((secconds/60), 60)
(4, 30)
>>> divmod((-secconds/60), 60)
(-5, 30)
>>> secconds / 60
270
>>> 270 / 60
4
>>> - 270 / 60
-5
>>>
I hope be clear and not to much verbose, but this is my first mail to the list.
Cheers and sorry for my English :)
nueces....
More information about the Zope-Dev
mailing list