Differences between revisions 4 and 5
Revision 4 as of 2008-03-06 21:15:51
Size: 4632
Editor: 207
Comment: Added an explanatory gloss for "timestamp".
Revision 5 as of 2008-05-19 13:08:49
Size: 4712
Editor: dyn2191873
Comment:
Deletions are marked like this. Additions are marked like this.
Line 162: Line 162:

= Printing to stderr =

{{{
print >> sys.stderr, 'entering function'
}}}

This is my user page. I'm going to use it to build docs I need that may then be worth moving elsewhere. To begin with...

Dates and Times

Python has two modules that relate to dates and times (that I know of so far):

  • datetime
  • time

These are reasonably well documented in the online material, but I have not so far found a page or site that pulls all the information about these modules together in one place so one can understand how they relate to each other. This section is an attempt at that. First, an overview of the modules.

datetime

The datetime module defines five classes:

  • date - a date (year, month, day)
  • time - a time within a day (hour, minute, second)
  • datetime - combines a datetime.date and datetime.time
  • timedelta - different between two datetime objects
  • tzinfo - "abstract base class for time zone info objects" [1]

time

The time module defines one class:

  • time - access to system time with some formatting support

I found myself confused by a couple of aspects of these modules:

  • datetime.time and time.time are completely different despite sharing a name.
  • 'datetime' is the name of both a module and a class.

From time.time, we can get the system time. We can then pass that information into an object of one of the datetime classes for more sophisticated formatting and date/time arithmetic. Some examples:

What time is it?

>>> import time
>>> now = time.time()
>>> now
1194011556.6974411
>>> int(now)
1194011556
>>> import datetime
>>> today = datetime.datetime.now()
>>> today
datetime.datetime(2007, 11, 2, 10, 33, 35, 713125)
>>> print today
2007-11-02 10:33:35.713125

How about in human-friendly format?

>>> import time
>>> time.asctime()
'Fri Nov  2 09:55:28 2007'

I don't like that format. How can I roll my own?

>>> import time
>>> time.strftime("%Y/%m/%d %H:%M:%S")
'2007/11/02 09:58:30'

The various format specifiers are described in the documentation for the time module at http://docs.python.org/lib/module-time.html.

What was the date 24 hours ago?

>>> import time
>>> now = time.time()
>>> now = now - 24 * 60 * 60
>>> time.strftime("%Y/%m/%d %H:%M:%S", time.localtime(now))
'2007/11/01 10:00:32'

I have a string representing a date/time. How do I turn it into something I can do computations on?

>>> import time
>>> then_str = "7 March 2000 4:38"
>>> time.strptime(then_str, "%d %B %Y %H:%M")
(2000, 3, 7, 4, 38, 0, 1, 67, -1)
>>> (y, m, d, h, min, sec, wd, julian, dst) = time.strptime(then_str, "%d %B %Y %H:%M")
>>> x = []
>>> x = time.strptime(then_str, "%d %B %Y %H:%M")
>>> x
(2000, 3, 7, 4, 38, 0, 1, 67, -1)
...

How do I turn the tuple into a timestamp (number of seconds since the epoch)?

...
>>> time.mktime(x)
952421880.0

How do I turn a timestamp into a datetime object?

>>> import time
>>> import datetime
>>> d = datetime.datetime.fromtimestamp(time.time())
>>> d
datetime.datetime(2007, 11, 2, 10, 25, 35, 947082)

How long between date/time A and date/time B?

>>> import time
>>> import datetime
>>> atup = (2000, 3, 7, 0, 0, 0, 0, 0, 0)
>>> btup = (2000, 12, 15, 0, 0, 0, 0, 0, 0)
>>> diff = time.mktime(btup) - time.mktime(atup)
>>> diff
24451200.0
>>> # or, using datetime....
>>> a = datetime.datetime.fromtimestamp(time.mktime(atup))
>>> b = datetime.datetime.fromtimestamp(time.mktime(btup))
>>> c = b - a
>>> c
datetime.timedelta(283)
>>> print c
283 days, 0:00:00

What was the date or timestamp of last Friday?

>>> import time
>>> now = time.time()
>>> tup = time.localtime()
>>> then = now - 24*60*60((7 + tup[6] - 4 - 1)%7 + 1)
>>> # or, using datetime
>>> import datetime
>>> today = datetime.datetime.now()
>>> today
datetime.datetime(2007, 11, 2, 11, 27, 50, 37655)
>>> diff = datetime.timedelta((7 + today.weekday() - 4 - 1)%7 + 1, 0, 0)
>>> last_friday = today - diff
>>> last_friday
datetime.datetime(2007, 10, 26, 11, 27, 50, 37655)

In general, to compute the date of last Z,

  • today - (7 + weekday - Z - 1) % 7 + 1

To compute the date of next Z,

  • today + (7 + Z - weekday - 1) % 7 + 1

This assumes that Monday = 0, Tuesday = 1, ..., Sunday = 6, as is the case in python.

Note that the computation must be carried out in units of days.

Can I give the datetime module a less cumbersome alias?

>>> import datetime as dt

References

[1] $ pydoc datetime.tzinfo

Printing to stderr

print >> sys.stderr, 'entering function'

TomBarron (last edited 2008-11-15 13:59:43 by localhost)

Unable to edit the page? See the FrontPage for instructions.