Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/date/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 为日期范围内的每个月生成(StartDateOfMonth,EndDateofMonth)_Python_Date_Python 2.7 - Fatal编程技术网

Python 为日期范围内的每个月生成(StartDateOfMonth,EndDateofMonth)

Python 为日期范围内的每个月生成(StartDateOfMonth,EndDateofMonth),python,date,python-2.7,Python,Date,Python 2.7,我想为指定的日期范围生成(StartDateOfMonth,EndDateOfMonth)值列表。e、 十、时间范围:2011-09-112013-04-24,列表应为: [('2011-9-11', '2011-9-30'), ('2011-10-01', '2011-10-31'), ('2011-11-01', '2011-11-30'), ('2011-12-01', '2011-12-31'), ('2012-1-01', '2012-1-31'), ('2012-2-01', '20

我想为指定的日期范围生成(StartDateOfMonth,EndDateOfMonth)值列表。e、 十、时间范围:2011-09-112013-04-24,列表应为:

[('2011-9-11', '2011-9-30'), ('2011-10-01', '2011-10-31'), ('2011-11-01', '2011-11-30'), ('2011-12-01', '2011-12-31'), ('2012-1-01', '2012-1-31'), ('2012-2-01', '2012-2-29'), ('2012-3-01', '2012-3-31'), ('2012-4-01', '2012-4-30'), ('2012-5-01', '2012-5-31'), ('2012-6-01', '2012-6-30'), ('2012-7-01', '2012-7-31'), ('2012-8-01', '2012-8-31'), ('2012-9-01', '2012-9-30'), ('2012-10-01', '2012-10-31'), ('2012-11-01', '2012-11-30'), ('2012-12-01', '2012-12-31'), ('2013-1-01', '2013-1-31'), ('2013-2-01', '2013-2-28'), ('2013-3-01', '2013-3-31'), ('2013-4-01', '2013-4-24')]
我想出了一个看起来有点难看的代码。这部分是因为我缺乏列表兼容性和Python的其他功能。代码是:

def getMonthRanges(startDate, endDate):
    dateRange = []

    allYears= [eachYear for eachYear in range(startDate.year, endDate.year+1)]
    allMonths= [eachMonth for eachMonth in range(1, 13)]

    for eachYear in allYears:
        for eachMonth in allMonths:
            if eachYear == startDate.year:
                if eachMonth == startDate.month:
                   startOfMonth = str(eachYear)+'-'+str(eachMonth) + '-'+str(startDate.day)
                   endOfMonth =   str(eachYear)+ '-'+str(eachMonth) + '-'+str(calendar.monthrange(eachYear, eachMonth)[1])
                   dateRange.append((startOfMonth, endOfMonth))
                elif eachMonth > startDate.month:
                   startOfMonth = str(eachYear)+ '-'+str(eachMonth) + '-01'
                   endOfMonth = str(eachYear)+'-'+str(eachMonth)+ '-'+ str(calendar.monthrange(eachYear, eachMonth)[1])
                   dateRange.append((startOfMonth, endOfMonth))
                else:
                    continue
            if eachYear == endDate.year:
                if eachMonth == endDate.month:
                    startOfMonth = str(eachYear)+'-'+str(eachMonth) + '-01'
                    endOfMonth =   str(eachYear)+ '-'+str(eachMonth) + '-'+str(endDate.day)
                    dateRange.append((startOfMonth, endOfMonth))
                    break
                elif eachMonth < endDate.month:
                    startOfMonth = str(eachYear)+ '-'+str(eachMonth) + '-01'
                    endOfMonth = str(eachYear)+'-'+str(eachMonth)+ '-'+ str(calendar.monthrange(eachYear, eachMonth)[1])
                    dateRange.append((startOfMonth, endOfMonth))
            elif eachYear > startDate.year and eachYear < endDate.year:
                startOfMonth = str(eachYear)+ '-'+str(eachMonth) + '-01'
                endOfMonth = str(eachYear)+'-'+str(eachMonth)+ '-'+ str(calendar.monthrange(eachYear, eachMonth)[1])
                dateRange.append((startOfMonth, endOfMonth))

    return dateRange
def getMonthRanges(开始日期,结束日期):
日期范围=[]
allYears=[startDate.year,endDate.year+1]范围内每个年份的每个年份
allMonths=[范围(1,13)内每个月的每个月]
对于所有年份的每一年:
所有月份中的每个月:
如果eachYear==startDate.year:
如果每个月==startDate.month:
startOfMonth=str(每个月)+'-'+str(每个月)+'-'+str(开始日期.天)
endOfMonth=str(eachYear)+'-'+str(eachMonth)+'-'+str(calendar.monthrange(eachYear,eachMonth)[1])
dateRange.append((开始月份,结束月份))
elif每个月>开始日期.月份:
startOfMonth=str(每个月)+'-'+str(每个月)+'-01'
endOfMonth=str(eachYear)+'-'+str(eachMonth)+'-'+str(calendar.monthrange(eachYear,eachMonth)[1])
dateRange.append((开始月份,结束月份))
其他:
持续
如果eachYear==endDate.year:
如果每个月==endDate.month:
startOfMonth=str(每个月)+'-'+str(每个月)+'-01'
endOfMonth=str(每个月)+'-'+str(每个月)+'-'+str(endDate.day)
dateRange.append((开始月份,结束月份))
打破
elif每个月startDate.year和eachYear

如果此代码可以压缩/改进,请向其他开发人员征求反馈意见?

这里有一种方法,只需使用:

import datetime as DT
import calendar
def getMonthRanges(startDate, endDate):
    while startDate <= endDate:
        year, month = startDate.year, startDate.month
        weekday, day = calendar.monthrange(year, month)
        end = min(DT.date(year, month, day), endDate)
        yield (startDate, end)
        startDate = end+DT.timedelta(days=1)

ranges = [map(str, interval) 
          for interval in getMonthRanges(DT.date(2011,9,11), DT.date(2013,4,24))]
print(ranges)
>>从日期时间导入日期,时间增量
>>>从pprint导入pprint
>>>def下个月(x):
“提前一个月的第一个月,必要时结束一年”
如果x.month<12:
返回x.replace(月=x.month+1,日=1)
返回x.replace(年=x.year+1,月=1)
>>>def getMonthRanges(开始日期、结束日期):
结果=[]
第一个=起始日期
第一次<结束日期:
nm=下个月(第一个月)
最后=分钟(结束日期,nm-时间增量(天数=1))
结果。追加([str(第一个)、str(最后一个)])
第一个=纳米
返回结果
>>>pprint(getMonthRanges(日期:2011年9月11日),日期:2013年4月24日)
[['2011-09-11', '2011-09-30'],
['2011-10-01', '2011-10-31'],
['2011-11-01', '2011-11-30'],
['2011-12-01', '2011-12-31'],
['2012-01-01', '2012-01-31'],
['2012-02-01', '2012-02-29'],
['2012-03-01', '2012-03-31'],
['2012-04-01', '2012-04-30'],
['2012-05-01', '2012-05-31'],
['2012-06-01', '2012-06-30'],
['2012-07-01', '2012-07-31'],
['2012-08-01', '2012-08-31'],
['2012-09-01', '2012-09-30'],
['2012-10-01', '2012-10-31'],
['2012-11-01', '2012-11-30'],
['2012-12-01', '2012-12-31'],
['2013-01-01', '2013-01-31'],
['2013-02-01', '2013-02-28'],
['2013-03-01', '2013-03-31'],
['2013-04-01', '2013-04-24']]

这里有一种方法,只需使用:

>>从日期时间导入日期,时间增量
>>>从pprint导入pprint
>>>def下个月(x):
“提前一个月的第一个月,必要时结束一年”
如果x.month<12:
返回x.replace(月=x.month+1,日=1)
返回x.replace(年=x.year+1,月=1)
>>>def getMonthRanges(开始日期、结束日期):
结果=[]
第一个=起始日期
第一次<结束日期:
nm=下个月(第一个月)
最后=分钟(结束日期,nm-时间增量(天数=1))
结果。追加([str(第一个)、str(最后一个)])
第一个=纳米
返回结果
>>>pprint(getMonthRanges(日期:2011年9月11日),日期:2013年4月24日)
[['2011-09-11', '2011-09-30'],
['2011-10-01', '2011-10-31'],
['2011-11-01', '2011-11-30'],
['2011-12-01', '2011-12-31'],
['2012-01-01', '2012-01-31'],
['2012-02-01', '2012-02-29'],
['2012-03-01', '2012-03-31'],
['2012-04-01', '2012-04-30'],
['2012-05-01', '2012-05-31'],
['2012-06-01', '2012-06-30'],
['2012-07-01', '2012-07-31'],
['2012-08-01', '2012-08-31'],
['2012-09-01', '2012-09-30'],
['2012-10-01', '2012-10-31'],
['2012-11-01', '2012-11-30'],
['2012-12-01', '2012-12-31'],
['2013-01-01', '2013-01-31'],
['2013-02-01', '2013-02-28'],
['2013-03-01', '2013-03-31'],
['2013-04-01', '2013-04-24']]

这可能更适合codereview.StackExchange为什么不使用?代码查找给定日期的一个月的第一天和最后一天:。剩下的问题是,从开始月份到结束月份,您应该使用
范围()
。@dm03514:我可以将问题转移到codereview吗?或者我必须重新发布整个问题吗?如果问题只是“查看我的代码”,那么它应该被移动。如果问题是“如何在Python中最好地做到这一点”,那么它就在正确的位置。这可能更适合codereview.stackexchangewhy不使用?代码查找给定日期的一个月的第一天和最后一天:。剩下的问题是,从开始月份到结束月份,您应该使用
范围()
。@dm03514:我可以将问题转移到codereview吗?或者我必须重新发布整个问题吗?如果
[['2011-09-11', '2011-09-30'], ['2011-10-01', '2011-10-31'], ['2011-11-01', '2011-11-30'], ['2011-12-01', '2011-12-31'], ['2012-01-01', '2012-01-31'], ['2012-02-01', '2012-02-29'], ['2012-03-01', '2012-03-31'], ['2012-04-01', '2012-04-30'], ['2012-05-01', '2012-05-31'], ['2012-06-01', '2012-06-30'], ['2012-07-01', '2012-07-31'], ['2012-08-01', '2012-08-31'], ['2012-09-01', '2012-09-30'], ['2012-10-01', '2012-10-31'], ['2012-11-01', '2012-11-30'], ['2012-12-01', '2012-12-31'], ['2013-01-01', '2013-01-31'], ['2013-02-01', '2013-02-28'], ['2013-03-01', '2013-03-31'], ['2013-04-01', '2013-04-24']]
>>> from datetime import date, timedelta
>>> from pprint import pprint

>>> def next_month(x):
        'Advance the first of the month, wrapping the year if necessary'
        if x.month < 12:
            return x.replace(month=x.month+1, day=1)
        return x.replace(year=x.year+1, month=1)

>>> def getMonthRanges(startDate, endDate):
        result = []
        first = startDate
        while first < endDate:
            nm = next_month(first)
            last = min(endDate, nm - timedelta(days=1))
            result.append([str(first), str(last)])
            first = nm
        return result

>>> pprint(getMonthRanges(date(2011, 9, 11), date(2013, 4, 24)))
[['2011-09-11', '2011-09-30'],
 ['2011-10-01', '2011-10-31'],
 ['2011-11-01', '2011-11-30'],
 ['2011-12-01', '2011-12-31'],
 ['2012-01-01', '2012-01-31'],
 ['2012-02-01', '2012-02-29'],
 ['2012-03-01', '2012-03-31'],
 ['2012-04-01', '2012-04-30'],
 ['2012-05-01', '2012-05-31'],
 ['2012-06-01', '2012-06-30'],
 ['2012-07-01', '2012-07-31'],
 ['2012-08-01', '2012-08-31'],
 ['2012-09-01', '2012-09-30'],
 ['2012-10-01', '2012-10-31'],
 ['2012-11-01', '2012-11-30'],
 ['2012-12-01', '2012-12-31'],
 ['2013-01-01', '2013-01-31'],
 ['2013-02-01', '2013-02-28'],
 ['2013-03-01', '2013-03-31'],
 ['2013-04-01', '2013-04-24']]