How to Create Calendar Reports from Access Queries

Posted on
6,420 Points
Last Modified:
Experience Level: Intermediate
crystal (strive4peace) - Microsoft MVP, Access
Love empowering people by teaching and helping them develop applications.
Have you created a query with information for a calendar? ... and then, abra-cadabra, the calendar is done?! I am going to show you how to make that happen.

Visualize your data!  ... really see it

To use the code to create a calendar from a query, simply import the (only) module (mod_HtmlCalendarReport_s4p) from the download (see Step 1, below)  into your working database (and then compile and save, of course). You can get the same code by choosing File, Import in the VBE (Visual Basic Editor -- Alt-F11) and choosing the BAS file.  

Importing VBA doesn't, of course, include easy-to-launch macros (even though the macros run VBA procedures) ... triggering them is a snap -- especially if you use a menu form with buttons and other controls.  

Please, as you make changes, rename the 'test' procedures to have more meaningful names depending on how you customize them and how they are used. And add your own comments ... and indent?

If you feel like sharing, your ideas are welcome, and appreciated.

Using vba:
Application.FollowHyperlink Create_HtmlCalendar(sQueryName)
  • will open a web page with the calendar created from the query specified by sQueryName
  • The Create_HtmlCalendar function creates the calendar as an HTML file (web page)
  •   it returns the path and filename when done.
  • You have a calendar file you can email and share with others.
  • you may wish to add VBA Error Handling (Basics video)

What do you need to know to use this feature?

If you are a seasoned expert, no explanation needed ...

but for those of you who want to use this ... but don't quite understand yet -- take a breath and see things from a different perspective. Don't be overwhelmed.  It is quite simple, once you get past the code thing. Just line up the data you want to show in the calendar using a query. Name the fields what is expected. Define some field, or calculation, to be CalDate, and then, optionally, the calendar title (CalTitle), and up to 3 pieces of text (Text1, Text2, Text3) to show on days.

Once you have the query ... use it to make a calendar. You do not need to understand each line of this code to use this feature in YOUR databases ... only how to call it to make it give you what you want

... but if you want to take the time to understand, that is great.  Ask questions below if you need help -- and remember, if you don't know, chances are that someone else doesn't either. I want to give you a good tool -- and share my love of Access. Realize that if you do ask questions, the 'answers' may just lead you to find the answers yourself -- learning never stops.

to make things really easy ...
There is a macro in the sample database that asks for a query name and then ... presto! a calendar is displayed!

... and it even works for parameter queries, which I do say lightly because not near enough testing was done. If you can reproduce a problem (for instance, date might be a problem for non_American and non-ISO formats), please post a comment specifying the details, and let's all fix it.

A Calendar Report for one month will be made as an HTML file (web page) -- so everyone with a browser, which is just about everyone! can see it too!

It just doesn't get any easier than this! Access is such a wonderful tool.

Please Like, Comment, and Share with your friends. Thank you.

Through sharing, we will all get better.

~ have an awesome day ~

Video Steps

1. Download sample database or BAS file

   Access Database: inside HTML_Calendar_170727_ACCDB.zip
   BAS module: inside  mod_HtmlCalendarReport_s4p__BAS.zip

2. Import the module, mod_HtmlCalendarReport_s4p, into your working database

3. Optionally, import the 2 macros as well

4. Make a query containing fieldnames:

  •   CalDate - required
  •   CalTitle - optional
  •   Text1 - optional
  •   Text2 - optional
  •   Text3 - optional

5. Sort by CalDate in Ascending order

6. Save query and copy the name

7. Run the mcr_CALENDAR-From-Query macro and paste name of query when prompted

8. ... OR call the Create_HtmlCalendar function

  • Query name or SQL is a required parameter
  • Path and File name, or part of a file name, are optional

9. Here is an example of the output:

Calendar Report as a web page

Featured Post

The new generation of project management tools

With monday.com’s project management tool, you can see what everyone on your team is working in a single glance. Its intuitive dashboards are customizable, so you can create systems that work for you.

Join & Write a Comment

A Case Study of using the Windows API to provide RS232 communications capability in Access without the use of Active-X controls.
Audit trails are very important in any system to hold people responsible for certain transactions and hold them to take ownership of their actions. This article is dedicated to all novice "Microsoft Access" developers.

Keep in touch with Experts Exchange

Tech news and trends delivered to your inbox every month