Rhodri James wrote:
On Fri, 09 Oct 2009 13:39:43 +0100, Tim Chase <python.l...@tim.thechases.com> wrote:

Month arithmetic is a bit of a mess, since it's not clear how
to map e.g. Jan 31 + one month.

"Jan 31 + one month" usually means "add one to the month value and then keep backing off the day if you get an exception making the date", so you'd get Feb 31, exception, Feb 30, exception, Feb 29, possibly an exception, and possibly/finally Feb 28th. This makes pretty intuitive sense to most folks and is usually what's meant.

I've found that issues and confusion stem more from the non-commutative reality that "Jan 31 + (1 month) + (-1 month) != Jan 31 + (-1 month) + (1 month)" or the non-associative "Jan 31 + (1 month + 1 month) != (Jan 31 + 1 month) + 1 month" :-/

I'd hazard a guess that what we're actually seeing is people mentally
rebasing their indices, i.e. counting from the end of the month rather
than the start, which makes "the last day of January" and "January 31"
not the same thing really.  Unfortunately we're very fuzzy about when
we do things like this, which makes it hard on a poor programmer.

And when someone says "January 30", do they really mean the day before
the last day of the month? Where would it end? :-)
--
http://mail.python.org/mailman/listinfo/python-list

Reply via email to