如何在Python中获取两个日期之间特定月份的天数 [英] How to get the number of Days in a Specific Month between Two Dates in Python

查看:733
本文介绍了如何在Python中获取两个日期之间特定月份的天数的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有两个日期字段campaign_start_datecampaign_end_date.我想计算campaign_start_datecampaign_end_date之间每个月的天数.

I have two date fields campaign_start_date and campaign_end_date. I want to count the number of days in each month that comes in-between the campaign_start_date and campaign_end_date.

例如:

campaign_start_date  = September 7 2017
campaign_end_date    = November 6 2017

解决方案应该是:

Total No:of days       = 61 days
No: of months          = 3 months
Month 1                = 9/7/2017 to 9/30/2017
Month 2                = 10/1/2017 to 10/31/2017
Month 3                = 11/1/2017 to 11/6/2017
No:of days in Month 1  = 24 days
No:of days in Month 2  = 31 days
No:of days in Month 3  = 6 days

如何使用Python实现此目标? 到目前为止,我已经实现:

How can I achieve this using Python? So far I have achieved:

@api.multi
    def print_date(self):
        start_date = datetime.strptime(self.start_date, "%Y-%m-%d %H:%M:%S")
        end_date = datetime.strptime(self.end_date, "%Y-%m-%d %H:%M:%S")
        campaign_start_date = date(start_date.year,start_date.month,start_date.day)
        campaign_end_date = date(end_date.year,end_date.month,end_date.day)
        duration = (campaign_end_date-campaign_start_date).days  
        return True

推荐答案

以天为单位计算持续时间:

Calculate the duration in days:

from datetime import date

campaign_start_date = date(2017, 9, 7)
campaign_end_date = date(2017, 10, 6)
duration = (campaign_end_date-campaign_start_date).days
print campaign_start_date, campaign_end_date, duration 

一些进一步计算的提示:

Some hints for further calculations:

import calendar

campaign_end_month_start = campaign_end_date.replace(day=1)
days_in_month_campaign_end = (campaign_end_date - campaign_end_month_start).days + 1

range_startmonth = calendar.monthrange(campaign_start_date.year, campaign_start_date.month)
campaign_start_month_ends = campaign_start_date.replace(day=range_startmonth[1])

days_in_month_campaign_begins = (campaign_start_month_ends - campaign_start_date).days

通过这种方式,您可以计算出广告系列每个月的天数(请注意检查campaign_end_date是否在另一个月份而不是campaign_start_date

This way you can calculate the number of days in each month of the campaign (keep in mind to check if campaign_end_date is in another month than campaign_start_date

对于计算,您还可以访问日期字段,例如

For calculations you can also access the fields of a date, e.g.

campaign_start_date.day
campaign_start_date.month
campaign_start_date.year

要计算广告系列中涉及的月份数并获取月份列表以计算每月的持续时间,您可以使用此列表(基于Python:是否将所有月份都保留在范围内?).在循环之前和之内将日期设置为1(current = current.replace(day=1))很重要,否则,当开始日期是一个月的31号,而下个月少于31天或者时间较长时,请跳过一个月:

To calculate the number of involved month in your campaign and to get a list of the month to calculate the duration per month you can use this (based on the answer of m.antkowicz in Python: get all months in range?). It's important to set the day to 1 (current = current.replace(day=1)) before and inside the loop, otherwise you skip a month when your startdate is 31st of a month and the next month is shorter than 31 days or if you have a longer period:

from datetime import date, datetime, timedelta    
current = campaign_start_date
result = [current]

current = current.replace(day=1)
while current <= campaign_end_date:
    current += timedelta(days=32)
    current = current.replace(day=1)
    result.append(datetime(current.year, current.month, 1))

print result, len(result)

打印(当您使用current.strftime('%Y-%m-%d')时:

['2017-09-07','2017-10-01','2017-11-01'] 3

['2017-09-07', '2017-10-01', '2017-11-01'] 3

现在您可以遍历结果列表并计算每月的天数:

now you can loop over the result list and calculate the number of days per months:

durations= []
for curr in result:
    curr_range = calendar.monthrange(curr.year, curr.month)
    curr_duration = (curr_range[1] - curr.day)+1
    if (curr.month < campaign_end_date.month):
        durations.append(curr_duration)
    else:
        durations.append(campaign_end_date.day)

print durations

为您提供所需的月x日中的天数"作为列表:

which gives you the desired "No:of days in Month x" as a list:

[24,31,6]

[24, 31, 6]

这篇关于如何在Python中获取两个日期之间特定月份的天数的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆