zoukankan      html  css  js  c++  java
  • Python 学习笔记:根据输入年月获取该月的第一天和最后一天

    目的:

          给定一个时间,比如: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

          自定义函数调用结果如下:

  • 相关阅读:
    sql server sa 用户 属性
    关于SQL执行顺序
    SQL server 数据库版本查询
    版本生成|Ext form输入框后加文字说明
    继承 tabpanel 对父类重新赋值 父类方法重写
    Ext.namespace() Ext命名空间介绍
    Ext.apply Ext.applyif 的理解
    下拉列表
    extjs表单FormPanel验证
    提高篇:第十三篇
  • 原文地址:https://www.cnblogs.com/Sunny20181123/p/10828503.html
Copyright © 2011-2022 走看看