Calculate the Last Day of the Month
June 23, 2022 - by Bill Jelen
data:image/s3,"s3://crabby-images/78275/78275810951b9fbdb994983f6b143e22afa811c2" alt="Calculate the Last Day of the Month Calculate the Last Day of the Month"
Problem: I need to calculate the last of the month. What the heck was that poem?
data:image/s3,"s3://crabby-images/c70dd/c70dd77a40273ff093174b609be9800e92e0f38c" alt="An ancient poem for remembering how many days are in a month is shown on the left. On the right, a very long Excel formula using CHOOSE, MONTH, IF, AND, MONTH, MOD, YEAR to simulate the poem. Luckily, there is an easier way."
Strategy: Don’t try coding that poem about the number of days. The DATE()
function will handle this easily, with one clever trick. Don’t try to go to the 31st or 30th or 28th of the month. Instead, go to the first of the next month and then subtract 1!
data:image/s3,"s3://crabby-images/822c6/822c63aef258831cbc99fb6627efd1c9c1080312" alt="With a date in D2, to find the end of the month, use =DATE(YEAR(D2),MONTH(D2)+1,1)-1. This gives you the first of next month and then subtracts one."
This is a clever approach, isn’t it?
How does it manage to work in December? You are asking for the first of the 13th month of 2023. Excel has no problem figuring out that =DATE(2023,13,1)
is January 1 of 2023. In fact, here is the 37th day of the 18th month of 2020:
data:image/s3,"s3://crabby-images/cafb1/cafb195becf8db786a1eca7cf2360dfa3b156424" alt="=DATE(2025,18,37) resolves to the 37th day of the 18th month of 2025. That gets you out to July 7, 2026."
The DATE
function can even sort of handle negatives, with one twist. A zero in the month or day argument is treated as “the item before 1”. Thus, using -1 as the month will actually go back two months.
data:image/s3,"s3://crabby-images/99087/99087a6d36fd3ca74642f504b2eee7dd74a2a02e" alt="=DATE(2025,1,1) gets you January 1. =DATE(2025,0,1) gets you December 1 2024. =DATE(2025,-1,1) gets you back to November 1 2024."
This previous trick makes the original question even easier. To go to the end of this month, you would go to the 0th of the next month. =DATE(YEAR(A2),MONTH(A2)+1,0)
.
data:image/s3,"s3://crabby-images/07972/07972897c8b2b3c5c44d49d407aa19d2bde3c6fb" alt="Three examples where =DATE(YEAR(D2),MONTH(D2)+1,0) gets you to the end of the month, even for dates in December."
If you are sure you won’t ever have to save the workbook as an XLS file, you can safely use the EOMONTH
function to show the end of this month, last month, two months from now, and so on.
data:image/s3,"s3://crabby-images/1e6b0/1e6b09f33ea9cad3c77bb4439cf074913e8063d0" alt="Starting in Excel 2007, the easier way to get to the end of this month is =EOMONTH(A4,0)"
This article is an excerpt from Power Excel With MrExcel
Title photo by Johannes W on Unsplash