It is 2023 and I made an improved version of the Excel Calendar with a neat design and highlight the holidays.
data:image/s3,"s3://crabby-images/0411f/0411f33cd666755d2ebb7bbefcac421d735e3021" alt=""
Day of Week Header
Firstly, input the year in cell $B$1
and create the day of week header. The day of week header only apply in row 2 and we use ROW()
to ensure this.
In cell B1
, type the below formula and copy to B1:H1
data:image/s3,"s3://crabby-images/d45a6/d45a6f42b33e2d2f140e4839ccbb71ef3e1f3c94" alt=""
Day of the year
To construct the calendar, we fill up the cells with the day of the year (0-365). We need to offset by WEEKDAY(DATE($B$1, 1, 1)
so day 0 fit in the correct day of week. It may not be easily noticed ince 1-Jan of 2023 is Sunday. It will be more clear if change the year to 2022.
data:image/s3,"s3://crabby-images/fe58d/fe58dd10aa55fe90f5bf5bc67b659b2836aefad5" alt=""
data:image/s3,"s3://crabby-images/e1420/e1420b48f6eb57744fe105105d7cd6be194a0f67" alt=""
Date Value
Now we add the first day of the year to to make it a date value so we can use conditional formatting to format it. Here we use TEXT()
to format the date for verification only. This will be removed in actual formula.
data:image/s3,"s3://crabby-images/267e2/267e247a3097da57979e5c6e65e414d6e3102310" alt=""
Hide the date that does not match the input year.
data:image/s3,"s3://crabby-images/b2530/b2530a220c242b0d3d94c6d0a9e88c847fe61dd5" alt=""
Fill up the worksheet
Copy the formula to cell A2:G55
to fill up the whole year
Format the calendar with Conditional Formatting
We then apply conditional formatting to format the calendar. Since the cell value is already a Date
. We can use the date format to show the month name or day of month number.
Select column A:G
and apply below Conditional Formatting:
Show month name
Use custom format mmm
to show the month name in the first day of the month
Formula:
Format:
Number -> Custom -> "mmm"
data:image/s3,"s3://crabby-images/25706/25706c86a2a45a257ebeec9bfd9c8bad2a7b9dd1" alt=""
data:image/s3,"s3://crabby-images/3d109/3d109b631054de30a72fe0ecfb880f806b08c11e" alt=""
Day number
Use custom format d
to show the day number of remaining days of the month
Formula:
Format:
data:image/s3,"s3://crabby-images/87cdb/87cdbb7b5bbf8843a23a908e1b5818ac7f7135d5" alt=""
data:image/s3,"s3://crabby-images/06f7d/06f7d74016a01be41365dd2e6b9ac64e316c9ffa" alt=""
Border of month
Add a bottom border if reach end of the month (i.e. the day of month of next row is smaller than current cell
Formula
Format:
Border -> Bottom border
data:image/s3,"s3://crabby-images/e0d21/e0d21d94977ff52a1badbf86b139b91760e6ef3e" alt=""
Add a right border for the last day of the month (i.e. the cell in the right is "1")
Formula
Format
data:image/s3,"s3://crabby-images/de7d5/de7d56d384d19754b2aa19b0aa00e0c88c9bb95d" alt=""
Holiday
We highlight Saturday and Sunday in red. Also we can input the holiday and use Vlookup
to mark the day as holiday as well.
Formula
Format
data:image/s3,"s3://crabby-images/de811/de8114ba92765503de14dae761ded224ce9ab651" alt=""
Protect Sheet
In last step, we unlock the cell $B$1
for input the year, and protect the worksheet
data:image/s3,"s3://crabby-images/b01c2/b01c21c6018f1fe01a13f24b3bd675c1490aaf2e" alt=""
data:image/s3,"s3://crabby-images/045ad/045ad2d497a487cd3526625929a2b9d5c6c0f595" alt=""
data:image/s3,"s3://crabby-images/0411f/0411f33cd666755d2ebb7bbefcac421d735e3021" alt=""