如果我有两个约会(例如。'8/18/2008'和'9/26/2008'),怎样才能得到这两个日期之间的天数?
当前回答
对于计算日期和时间,有几个选项,但我将写简单的方式:
from datetime import timedelta, datetime, date
import dateutil.relativedelta
# current time
date_and_time = datetime.now()
date_only = date.today()
time_only = datetime.now().time()
# calculate date and time
result = date_and_time - timedelta(hours=26, minutes=25, seconds=10)
# calculate dates: years (-/+)
result = date_only - dateutil.relativedelta.relativedelta(years=10)
# months
result = date_only - dateutil.relativedelta.relativedelta(months=10)
# week
results = date_only - dateutil.relativedelta.relativedelta(weeks=1)
# days
result = date_only - dateutil.relativedelta.relativedelta(days=10)
# calculate time
result = date_and_time - timedelta(hours=26, minutes=25, seconds=10)
result.time()
希望能有所帮助
其他回答
如果您有两个date对象,您可以将它们相减,这将计算一个timedelta对象。
from datetime import date
d0 = date(2008, 8, 18)
d1 = date(2008, 9, 26)
delta = d1 - d0
print(delta.days)
文档的相关部分: https://docs.python.org/library/datetime.html。
请看另一个例子。
如果您没有日期处理库(或者您怀疑它有bug),这里有一个抽象算法,应该可以很容易地翻译成大多数语言。
在每个日期执行以下计算,然后简单地减去两个结果。所有的商和余数都是正整数。
步骤a:首先确定日期的部分为Y(年),M(月)和D(日)。这些变量会随着我们的进行而改变。
步骤b: M减去3
(所以一月是-2,十二月是9)。
步骤c:如果M是负的,M加12,Y减1。
(这将“一年的开始”更改为3月1日,月份编号为0(3月)到11(2月)。这样做的原因是为了“一年之内的天数”在闰年和普通年之间不会改变,这样“短”的月份就在一年的年底,所以下一个月就不需要特殊处理了。)
步骤D。 M除以5得到商Q₁,余数R₁。在d上增加Q₁× 153,下一步使用R₁。
(从3月1日开始,每5个月有153天。)
步骤E.将R₁除以2得到商Q₂,忽略余数。在D上加R₁× 31 - Q₂。
(在每组5个月中,每2个月有61天,每对月的第一个月为31天。忽略2月比30天短的事实是安全的,因为在这一点上你只关心2月1日的天数,而不是第二年的3月1日。)
步骤D & E组合-替代法
在第一次使用之前,设置L=[0,31,61,92,122,153,184,214,245,275,306,337]
(这是在每个月的第一天之前的(调整后的)年的累计天数。)
在D后面加上L[M]。
步骤F 如果你使用儒略历日期而不是公历日期,请跳过这一步;这个日期在不同的国家有所不同,但在大多数英语国家是1752年9月3日,在大多数欧洲国家是1582年10月4日。
如果您确定永远不需要处理1-Mar-1900到28-Feb-2100范围之外的日期,您也可以跳过这一步,但随后必须对您处理的所有日期做出相同的选择。
Y₃除以100,得到Q₃,余数R₃。将Q₃除以4,得到另一个商式Q₄,忽略余数。在D中加入Q₄+ 36524 × Q₃。
将R₃₃Y。
一步G。 将Y除以4得到商Q₅,并忽略其余部分。在D上增加Q₅+ 365 × Y。
步骤H.(可选) 您可以在D中添加您选择的常数,以强制某个特定日期具有特定的日号。
对每个日期执行步骤A~G,得到D₁和D₂。
我一步。 D₁与D₂相减,得到D₂在D₁后的天数。
最后,一个评论:在处理1760年之前的日期时要格外谨慎,因为对哪一个月是一年的开始没有一致意见;许多地方把3月1日作为新年。
它也可以很容易地用箭头完成:
import arrow
a = arrow.get('2017-05-09')
b = arrow.get('2017-05-11')
delta = (b-a)
print delta.days
参考:http://arrow.readthedocs.io/en/latest/
如果你想自己编写计算代码,那么这里有一个函数,它将返回给定年、月和日的序数:
def ordinal(year, month, day):
return ((year-1)*365 + (year-1)//4 - (year-1)//100 + (year-1)//400
+ [ 0,31,59,90,120,151,181,212,243,273,304,334][month - 1]
+ day
+ int(((year%4==0 and year%100!=0) or year%400==0) and month > 2))
此功能与日期兼容。datetime模块中的Toordinal方法。
两个日期的差日数如下所示:
print(ordinal(2021, 5, 10) - ordinal(2001, 9, 11))
使用datetime函数:
from datetime import datetime
date_format = "%m/%d/%Y"
a = datetime.strptime('8/18/2008', date_format)
b = datetime.strptime('9/26/2008', date_format)
delta = b - a
print delta.days # that's it
推荐文章
- Visual Studio Code:如何调试Python脚本的参数
- 使用元组/列表等等。从输入vs直接引用类型如list/tuple/etc
- 结合conda环境。Yml和PIP requirements.txt
- 将命名元组转换为字典
- 如何使x轴和y轴的刻度相等呢?
- Numpy在这里函数多个条件
- 在Python中,使用argparse只允许正整数
- 如何排序mongodb与pymongo
- 不可变与可变类型
- 列表是线程安全的吗?
- 在Android应用程序中显示当前时间和日期
- 字符串不能识别为有效的日期时间“格式dd/MM/yyyy”
- 操作系统。makdirs在我的路径上不理解“~”
- 如何在Django模板中获得我的网站的域名?
- 如何转换日期时间?将日期时间