对比Excel,怎么用Python获取指定时间最后一天的日期

举报
yd_226342373 发表于 2021/05/22 23:49:19 2021/05/22
【摘要】 这是群友的一个需求。他想根据一个给定的日期,获取该给定日期在这个年月的最后一天的日期,并且要求在Python中怎么做。基于此,我就想到了对比Excel,在Python中完成这个需求。 Excel完成这个需求 ① 在单元格中输入EOMONTH()公式 ② 完成填充操作 ③ 将时间戳转换为短日期格式 可以看到在excel中输入该公式后,默认返回的是一个时...

这是群友的一个需求。他想根据一个给定的日期,获取该给定日期在这个年月的最后一天的日期,并且要求在Python中怎么做。基于此,我就想到了对比Excel,在Python中完成这个需求。
在这里插入图片描述

Excel完成这个需求

① 在单元格中输入EOMONTH()公式

在这里插入图片描述

② 完成填充操作

在这里插入图片描述

③ 将时间戳转换为短日期格式

可以看到在excel中输入该公式后,默认返回的是一个时间戳,我们需要将其转换为我我们需要的短日期格式。
在这里插入图片描述

Python完成这个需求

在完成这个需求之前,我们先来讲述几个知识点,否则你会看着懵逼。

1)datetime库中的知识点

import datetime

date1 = datetime.date.today()
print(date1)

year = datetime.date.today().year
print(year)`

month = datetime.date.today().month
print(month)

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

结果如下:
在这里插入图片描述
可以看出:上面我们使用today()函数直接获取了当前系统的年月,并且利用year和month属性分别获取了当前系统时间的年、月。

接下来,我们使用该模块获取指定年、月的指定日期,其中day=1表示获取当前年月的第一天,day=2表示获取当前年月的第二天…依次进行下去。

date1 = datetime.date(year=year, month=month, day=1)
print(date1)

date2 = datetime.date(year=year, month=month, day=2)
print(date2)

  
 
  • 1
  • 2
  • 3
  • 4
  • 5

结果如下:
在这里插入图片描述
通过上述演示,应该可以知道怎么完成这个需求了吧?当我们指定了年月,后面只需要传入day=当月的总天数这个参数,得到的不就是该年月的最后一天的日期吗?因此目前的问题就是怎么获取某个月的最后一天,这就是下面需要讲述的monthrange()函数。

2)calendar库中的知识点

对于这个模块,我主要讲述一个monthrange()函数,这个函数是有什么用呢?

  • monthrange(year, month):返回指定年月,由第一天所在的星期和本月的总天数组成的元组。
# 这里的year和month就是上面提到的2020和7
import calendar

x, y = calendar.monthrange(year, month)
print(x, y)
"""
其中:x表示2020/7/1号所在的星期数,其中周一是0,周二是1,周三是2。 y表示的是2020年7月这个月的总天数。
"""

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

结果如下:
在这里插入图片描述

3)完整代码如下

import datetime
import calendar

def func(year=None, month=None): if year: year = int(year) else: year = datetime.date.today().year if month: month = int(month) else: month = datetime.date.today().month # x:表示当月第一天所属的星期 # y:表示当月的总天数 x, y = calendar.monthrange(year, month) # 获取当月的第一天和最后一天 first_day = datetime.date(year=year, month=month, day=1) last_day = datetime.date(year=year, month=month, day=y) return first_day, last_day

first_day, last_day = func()
print(first_day, last_day)

first_day, last_day = func(2020,6)
print(first_day, last_day)

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29

结果如下:
在这里插入图片描述
这个代码其实很好理解:如果year和month为空,就返回的是当前系统时间的最后一天的日期。如果传入指定年月,那么获取的就是指定年月的最后一天的日期。

文章来源: blog.csdn.net,作者:数据分析与统计学之美,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/weixin_41261833/article/details/107579899

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。