目的:
给定一个时间,比如:2020.02,要求返回所输入月份的第一天及最后一天,比如:('2020.02.01', '2020.02.29')
参考博客:https://blog.csdn.net/gou_can/article/details/88052875
思路:
已知年月,每月的第一天当然是1号啦,所以接下来只要能求得输入月份的最后一天即可,这里我们可以利用 Python 的 calendar 模块下的 monthrange 函数来实现。
首先可以看下以下代码:
import calendar calendar.monthrange(2019,5)
输出结果:(2, 31)
解析:
这里使用了函数 calendar.monthrange(year,month),该函数返回两个整数:
第一个整数是该月首日所在的星期的日期码(0-6);
第二个整数是该月的天数(28-31);
上面输入的时间是:2019年5月;得到的结果是:(2, 31),即,5月1号是星期三(日期码为2),这个月有31天,可以从日历验证这一结果;而且,每月的天数也是每个月最后一天的日期,根据这一特点,我们可以利用这一函数来获取每个月的最后一天,OK,问题解决。
代码实现:
根据上面的思路,定义以下函数:
import calendar
def get_current_month_start_and_end(date): if str(date).count('.') != 1: raise ValueError("Pls input parameter such as '2019.05'") #要求参数格式是:xxxx.xx,可自行设定,此处省去其他验证 year,month = str(date).split('.')[0], str(date).split('.')[1] #分割字符串,提取年月 end = calendar.monthrange(int(year), int(month))[1] #获取当前年月的当月天数 start_date = '%s.%s.01' %(year,month) #第一天 end_date = '%s.%s.%s' %(year,month,end) #最后一天 return start_date,end_date
自定义函数调用结果如下: