對(duì)比Excel,怎么用Python獲取指定月最后一天的日期
這是群友的一個(gè)需求。他想根據(jù)一個(gè)給定的日期,獲取該給定日期在這個(gè)年月的最后一天的日期,并且要求在Python中怎么做?;诖?,我就想到了對(duì)比Excel,在Python中完成這個(gè)需求。
Excel完成這個(gè)需求
① 在單元格中輸入EOMONTH()公式
② 完成填充操作
③ 將時(shí)間戳轉(zhuǎn)換為短日期格式
可以看到在excel中輸入該公式后,默認(rèn)返回的是一個(gè)時(shí)間戳,我們需要將其轉(zhuǎn)換為我我們需要的短日期格式。
Python完成這個(gè)需求
在完成這個(gè)需求之前,我們先來(lái)講述幾個(gè)知識(shí)點(diǎn),否則你會(huì)看著懵逼。
1)datetime庫(kù)中的知識(shí)點(diǎn)
- import datetime
- date1 = datetime.date.today()
- print(date1)
- year = datetime.date.today().year
- print(year)`
- month = datetime.date.today().month
- print(month)
結(jié)果如下:
可以看出:上面我們使用today()函數(shù)直接獲取了當(dāng)前系統(tǒng)的年月,并且利用year和month屬性分別獲取了當(dāng)前系統(tǒng)時(shí)間的年、月。
接下來(lái),我們使用該模塊獲取指定年、月的指定日期,其中day=1表示獲取當(dāng)前年月的第一天,day=2表示獲取當(dāng)前年月的第二天......依次進(jìn)行下去。
- date1 = datetime.date(year=year, month=month, day=1)
- print(date1)
- date2 = datetime.date(year=year, month=month, day=2)
- print(date2)
結(jié)果如下:
通過(guò)上述演示,應(yīng)該可以知道怎么完成這個(gè)需求了吧?當(dāng)我們指定了年月,后面只需要傳入day=當(dāng)月的總天數(shù)這個(gè)參數(shù),得到的不就是該年月的最后一天的日期嗎?因此目前的問(wèn)題就是怎么獲取某個(gè)月的最后一天,這就是下面需要講述的monthrange()函數(shù)。
2)calendar庫(kù)中的知識(shí)點(diǎn)
對(duì)于這個(gè)模塊,我主要講述一個(gè)monthrange()函數(shù),這個(gè)函數(shù)是有什么用呢?
- monthrange(year, month):返回指定年月,由第一天所在的星期和本月的總天數(shù)組成的元組。
- # 這里的year和month就是上面提到的2020和7
- import calendar
- x, y = calendar.monthrange(year, month)
- print(x, y)
- """
- 其中:x表示2020/7/1號(hào)所在的星期數(shù),其中周一是0,周二是1,周三是2。
- y表示的是2020年7月這個(gè)月的總天數(shù)。
- """
結(jié)果如下:
3)完整代碼如下
- 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:表示當(dāng)月第一天所屬的星期
- # y:表示當(dāng)月的總天數(shù)
- x, y = calendar.monthrange(year, month)
- # 獲取當(dāng)月的第一天和最后一天
- 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)
結(jié)果如下:
這個(gè)代碼其實(shí)很好理解:如果year和month為空,就返回的是當(dāng)前系統(tǒng)時(shí)間的最后一天的日期。如果傳入指定年月,那么獲取的就是指定年月的最后一天的日期。