3.12 基本的日期与时间转换

问题

你需要执行简单的时间转换,比如天到秒,小时到分钟等的转换。

解决方案

为了执行不同时间单位的转换和计算,请使用 datetime 模块。比如,为了表示一个时间段,可以创建一个 timedelta 实例,就像下面这样:

  1. >>> from datetime import timedelta
  2. >>> a = timedelta(days=2, hours=6)
  3. >>> b = timedelta(hours=4.5)
  4. >>> c = a + b
  5. >>> c.days
  6. 2
  7. >>> c.seconds
  8. 37800
  9. >>> c.seconds / 3600
  10. 10.5
  11. >>> c.total_seconds() / 3600
  12. 58.5
  13. >>>

如果你想表示指定的日期和时间,先创建一个 datetime 实例然后使用标准的数学运算来操作它们。比如:

  1. >>> from datetime import datetime
  2. >>> a = datetime(2012, 9, 23)
  3. >>> print(a + timedelta(days=10))
  4. 2012-10-03 00:00:00
  5. >>>
  6. >>> b = datetime(2012, 12, 21)
  7. >>> d = b - a
  8. >>> d.days
  9. 89
  10. >>> now = datetime.today()
  11. >>> print(now)
  12. 2012-12-21 14:54:43.094063
  13. >>> print(now + timedelta(minutes=10))
  14. 2012-12-21 15:04:43.094063
  15. >>>

在计算的时候,需要注意的是 datetime 会自动处理闰年。比如:

  1. >>> a = datetime(2012, 3, 1)
  2. >>> b = datetime(2012, 2, 28)
  3. >>> a - b
  4. datetime.timedelta(2)
  5. >>> (a - b).days
  6. 2
  7. >>> c = datetime(2013, 3, 1)
  8. >>> d = datetime(2013, 2, 28)
  9. >>> (c - d).days
  10. 1
  11. >>>

讨论

对大多数基本的日期和时间处理问题, datetime 模块已经足够了。如果你需要执行更加复杂的日期操作,比如处理时区,模糊时间范围,节假日计算等等,可以考虑使用 dateutil模块

许多类似的时间计算可以使用 dateutil.relativedelta() 函数代替。但是,有一点需要注意的就是,它会在处理月份(还有它们的天数差距)的时候填充间隙。看例子最清楚:

  1. >>> a = datetime(2012, 9, 23)
  2. >>> a + timedelta(months=1)
  3. Traceback (most recent call last):
  4. File "<stdin>", line 1, in <module>
  5. TypeError: 'months' is an invalid keyword argument for this function
  6. >>>
  7. >>> from dateutil.relativedelta import relativedelta
  8. >>> a + relativedelta(months=+1)
  9. datetime.datetime(2012, 10, 23, 0, 0)
  10. >>> a + relativedelta(months=+4)
  11. datetime.datetime(2013, 1, 23, 0, 0)
  12. >>>
  13. >>> # Time between two dates
  14. >>> b = datetime(2012, 12, 21)
  15. >>> d = b - a
  16. >>> d
  17. datetime.timedelta(89)
  18. >>> d = relativedelta(b, a)
  19. >>> d
  20. relativedelta(months=+2, days=+28)
  21. >>> d.months
  22. 2
  23. >>> d.days
  24. 28
  25. >>>

原文:

http://python3-cookbook.readthedocs.io/zh_CN/latest/c03/p12_convert_days_to_seconds_and_others.html