Hourly Time Slot Booking Template in Google Sheets

Published on

In this post, we will provide an hourly time slot booking template in Google Sheets along with the formulas used to create it.

Here’s how it works: you select a start date to view the status of booked time slots in that week for various items. The items can include car/bike/equipment rental, tasks, hourly-based room booking, or anything that you allow booking on an hourly basis.

The template operates as follows: choose the item from column A, enter the start datetime and end datetime in columns C and D. Then, select whether the booking is confirmed or tentative in column F.

In another sheet, you can view the booked status in a bar chart with two distinguishable colors: orange represents tentative bookings, and green represents confirmed bookings.

Below, I’ll provide you with a free download link to my hourly time slot booking template in Google Sheets and instructions on how to use it.

Additionally, you will receive all the formulas and explanations. These will enable you to modify the template, such as inserting or moving columns in the input sheet.

Explore Our Intuitive Dynamic Hourly Time Slot Booking Template Interface

Our hourly time slot booking template in Google Sheets consists of two sheets: “Bookings” and “Status.” You can preview and copy it using the following template preview link.

Template

Let’s begin by exploring the “Status” sheet.

Status Sheet

Begin by entering all the items available for booking in the range A4:A. You can replace the existing items and add new ones as needed. Please ensure there are no duplicates.

Interface for Hourly Time Slot Booking Template

Highlighting occurs within the “Status” sheet as follows:

  • Available Time Slots: Black-colored cells in the grid represent available booking slots.
  • Booked Slots: Orange-highlighted cells represent tentative bookings, and green-highlighted cells represent confirmed bookings.

Since this is an hourly time slot booking template, each cell in the grid represents one hour.

The name of the individual who booked the time slot will appear in the very first cell. If a person booked for 2 hours, the highlighting will span two cells, and the first cell will contain their name.

There is a specific reason for displaying individuals’ names in our hourly time slot booking template. Without names, it would be challenging to identify the start time of the second person’s booking if, for instance, one person booked from 10:00 to 12:00 and another from 12:00 to 18:00.

You can select the status start date by double-clicking on cell C1. The bars in the grid and the date/time in the chart timescale at the top will refresh accordingly. The template is set to display 7 days from the selected date, resulting in 168 (7 x 24) time slots in each row for each item.

In summary, input all the available booking items in cells A4:A and select a start date from cell C1. The formulas will handle the rest.

Booking Sheet

This is the second sheet in our hourly time slot booking template in Google Sheets.

Data Input Sheet for Items, Bookings, Start and End DateTimes

The drop-down lists in cell range A3:A will display the items you entered in range A4:A on the “Status” sheet. Therefore, please ensure that you enter all the items available for booking in the “Status” sheet’s range A4:A.

Select an item in cell A3. Enter the booked person’s name in cell B3, followed by the booking start time (timestamp) and end time (timestamp) in C3:D3.

Remember, ours is an hourly time slot booking template, so you should only enter the hour component in the time, skipping seconds and minutes.

Then, select either “Tentative” or “Confirmed” in cell F3.

Continue this process in the rows below.

That’s all you need to input in the “Booking” sheet of our hourly time slot booking template in Google Sheets.

Observing the following points when inputting data in the “Booking” sheet will help you generate correct status bars in the “Status” Sheet.

  • Start and End times must be timestamps.
  • Minutes and seconds are not supported in the start and end times.
    • If a person booked for 1 hour, it should be like this:
      • Start: 02/09/2023 14:00:00
      • End: 02/09/2023 15:00:00
    • Not like this:
      • Start: 02/09/2023 14:00:00
      • End: 02/09/2023 14:00:00.
  • Before booking, refer to the “Status” sheet for available time slots to avoid errors, such as overlapping dates in the same item booking.

Formulas Utilized in the Hourly Time Slot Booking Template in Google Sheets

I haven’t used any scripts in our template. I’ve utilized native functions within the sheet for highlighting and other purposes. All the formulas are array formulas, meaning they will automatically adjust as your data grows. You don’t need to worry about dragging down the fill handle or copying and pasting them.

Here are the formulas used in our hourly time slot booking template in Google Sheets.

Highlight Rules

There are two conditional format rules in the “Status” Sheet for plotting the bars.

Highlight Rules in the Hourly Time Slot Booking Template

1. Confirmed Booking of Time Slots (Green)

The following formula is used within Format > Conditional format > Custom formula rule for the “Apply to range” C4:FN53 to plot the green color bars that represent confirmed time slot bookings.

=LET(
     start_end, "Booking!C3:D", 
     booked_item, "Booking!A3:A", 
     status, "Booking!F3:F", 
     item, $A4, 
     datetime, C$3, 
     ftr, 
     FILTER(INDIRECT(start_end), (INDIRECT(booked_item)=item)*
     (INDIRECT(status)="Confirmed")), 
     SUM(
        MAP(CHOOSECOLS(ftr, 1), INDEX(CHOOSECOLS(ftr, 2)-TIME(1, 0, 0), 0), 
        LAMBDA(st, en, N(ISBETWEEN(datetime, st, en))))
     )
)

Formula Breakdown:

We used the LET function to define names for ranges, making the formula more readable and efficient. Here are the defined names and value expressions:

  • start_end: “Booking!C3:D”
  • booked_item: “Booking!A3:A”
  • status: “Booking!F3:F”
  • item: $A4
  • datetime: C$3
  • ftr: FILTER(INDIRECT(start_end), (INDIRECT(booked_item)=item)*(INDIRECT(status)="Confirmed"))

The formula expression is as follows:

SUM(MAP(CHOOSECOLS(ftr, 1), INDEX(CHOOSECOLS(ftr, 2)-TIME(1, 0, 0), 0), LAMBDA(st, en, N(ISBETWEEN(time, st, en)))))

The MAP function tests whether the time in the “Status” sheet C3 is between the filtered start and end datetimes (ftr) in each row, returning an array of zeros and ones. The SUM function totals the result. If it’s >0, the corresponding time slot below C3 is highlighted.

In the formula, cell references $A4 and C$3 use a combination of relative and absolute cell references.

This configuration ensures that each cell in the grid is tested and highlighted appropriately as the formula is extended to different cells within the sheet.

2. Tentative Booking of Time Slots (Orange)

This is essentially a copy of the above formula. The only difference lies in the criteria part of the FILTER function, where we replaced INDIRECT(status)="Confirmed") with INDIRECT(status)="Tentative").

Formula to Display Names in the Status Bar

One distinctive feature of our hourly time slot booking template is the presentation of the names of booked individuals on the time slots within the bar. This feature facilitates distinguishing between continuous bookings of time slots by different individuals.

To achieve this, the following formula is employed in cell C4 on the “Status” sheet:

=LET(
   datetime, C3:3, 
   item, A4:A, 
   name, Booking!$B$3:$B, 
   r_item, Booking!$A$3:$A,
 
   start, Booking!$C$3:$C, 
   MAP(datetime, LAMBDA(c, MAP(item, LAMBDA(r, 
      JOIN(" ?", IFNA(FILTER(name, (r_item=r)*(start=c))))
   ))))
)

Formula Breakdown:

Defined names and value expressions in the LET function:

  • datetime: C3:3
  • item: A4:A
  • name: Booking!$B$3:$B
  • r_item: Booking!$A$3:$A
  • start: Booking!$C$3:$C

The formula expression is as follows:

MAP(datetime, LAMBDA(c, MAP(item, LAMBDA(r, JOIN(" ?", IFNA(FILTER(name, (r_item=r)*(start=c))))))))

The formula is straightforward to understand. The FILTER function filters the names of individuals who booked time at a particular time (C3) and for a specific item (A4).

To cover each row (C3:3) and column (A4:A), two MAP functions are utilized.

Dynamic Timescale for the Hourly Time Slot Booking Template

In cell C3 of the “Status” sheet, the following formula generates datetimes for the hourly time slot booking template:

=ARRAYFORMULA(C1+SEQUENCE(1, 7*24, 0)/24)
Dynamic Timescale covering 24 hours, 7 days

I’ve formatted the range C3:3 to “HH:MM” using Format > Number > Custom date and time.

The SEQUENCE function produces numbers from 1 to 168. By dividing these numbers by 24 and adding the result to the date in cell C1, we obtain the desired datetime values.

Optional Formulas in the Hourly Time Slot Booking Template

There are two optional formulas: one in Status!C2 and the other in Booking!E2.

Formula in C2 (Status Sheet):

The formula shows the dates for each 24 hours in the timescale.

=ArrayFormula(IF(MOD(C3:FN3, 1)=TIME(0, 0, 0), INT(C3:FN3),))
Formula displaying dates for each 24-hour period in the timescale

Explanation:

  • The MOD function, MOD(C3:FN3, 1), extracts the time component from the datetime values in cells C3 to FN3. The IF function evaluates the extracted time values and returns the corresponding dates in cells C3 to FN3 wherever the MOD function returns 00:00.

Formula in E2 (Booking Sheet):

This formula returns the duration from the time slot booking start and end datetimes:

=ARRAYFORMULA(VSTACK("Duration", IF(A3:A="",,D3:D-C3:C)))
Booking Duration in the Hourly Time Slot Booking Template

Explanation:

  • IF(A3:A="",,D3:D-C3:C): Calculates the duration only if there is a booking (if A3:A is not empty).
  • VSTACK("Duration", …): VSTACK stacks the label “Duration” above the calculated durations.

Conclusion

In conclusion, this user-friendly and efficient hourly time slot booking template in Google Sheets simplifies the process of managing appointments and reservations.

This version is an extension of our Reservation and Booking Status Calendar Template in Google Sheets, designed for per-day booking management.

Both templates feature an intuitive design and automated features, making scheduling a breeze.

Feel free to customize and utilize this hourly time slot booking template to streamline your time management, ensuring a seamless and organized booking experience for both you and your clients.

Enhance productivity and eliminate scheduling hassles with this convenient tool at your fingertips.

Prashanth KV
Prashanth KV
Your Trusted Google Sheets and Excel Guide Prashanth KV brings a wealth of experience in Google Sheets and Excel, cultivated through years of work with multinational corporations in Mumbai and Dubai. As a recognized Google Product Expert in Docs Editors, Prashanth shares his expertise through insightful blogging since 2012. Explore his blog for practical tips and guidance on maximizing your spreadsheet skills.

How to Extract Numbers from Text in Excel with Regex

You can use the REGEXEXTRACT or REGEXREPLACE functions to easily extract numbers from text...

Using OFFSET and MATCH Together in Google Sheets: Advanced Tips

One powerful and flexible way to look up values is by combining the OFFSET...

How to Use OFFSET and XMATCH Functions Together in Excel

We often use the OFFSET and XMATCH functions together to match a value in...

How to Calculate Maximum Drawdown in Excel and Google Sheets

You can use the following dynamic array formula to calculate maximum drawdown (MDD) in...

More like this

Using OFFSET and MATCH Together in Google Sheets: Advanced Tips

One powerful and flexible way to look up values is by combining the OFFSET...

Running Count with Structured References in Google Sheets

Running a count with structured references is achievable in Google Sheets tables using the...

Running Total with Structured Table References in Google Sheets

You can use two types of formulas to create a running total with structured...

9 COMMENTS

  1. Hi Prashanth,

    Thank you so much for your help! I am wondering if the time range on the Status sheet can be adjusted to a desired time range?

    I really appreciate your support.

    Kind regards.

    • Hi JY,

      It’s currently set to one week (24 x 7). If you want to limit it to one day or a specific range, you can hide the unwanted columns by grouping them.

      For example, you can select columns AA to FN, then right-click and choose “View more column actions” > “Group columns AA – FN.”

      Currently, no other customizations are supported.

  2. Hi Prashanth,

    Firstly, I want to thank you for providing this very detailed and excellent file. Secondly, I would like to ask if you have this version available in Excel format. I’ve attempted to convert the file myself, as Excel tends to be faster and allows for accessing more information without encountering bugs or lengthy update times. However, I keep encountering errors.

    Do you happen to have this file in Excel format?

    • Thanks for your feedback. Unfortunately, the file won’t function properly in Excel because it relies on the ARRAYFORMULA function, which isn’t available in Excel. Even if you attempt to convert it, please make sure to do so in Excel 365 only. We do have plans for an Excel version in the pipeline. I’ll keep you updated if I release one.

      • Hi Prashanth,

        Thank you for your help. I would like to know if it is possible to recreate this formula and adapt it for Excel. I’ve done everything else, and the only thing missing is this formula:

        =LET(
        datetime; D3:3;
        item; A4:A;
        name; Booking!$B$3:$B;
        r_item; Booking!$A$3:$A;
        start; Booking!$C$3:$C;
        MAP(datetime; LAMBDA(c; MAP(item; LAMBDA(r;
        JOIN(" ?"; IFNA(FILTER(name; (r_item=r)*(start=c))))
        ))))
        )

        • There are three issues. The first is the JOIN function; you should use TEXTJOIN in Excel. The second issue is the nested MAP function, which won’t work in Excel. You should replace one of the MAP functions with REDUCE.

          Additionally, the Lambdas might not work in conditional formatting in Excel. However, we can resolve these issues with some changes and functional adjustments. I’m working on converting the template to Excel, which will take a few more days. I’ll update you soon.

  3. Hi Prashanth,

    Thank you so much for your help! I’m trying to expand the calendar view in Google Sheets from 7 days to either 15 days or a full month, but I’m struggling to correctly adjust the formula =ARRAYFORMULA(A2+SEQUENCE(1, 7*24, 0)/24). Could you guide me on how to modify it or suggest an alternative?

    I really appreciate your support.

    Kind regards.

    • You need to first determine the number of columns required by multiplying number_of_days * 24, for example, 15 * 24. Insert that many columns into your sheet.

      In the formula, replace 7*24 with 15 or 30*24.

      If you choose 30 * 24, please note that the formula requires 720 columns, and the conditional formatting might struggle with such a large range.

LEAVE A REPLY

Please enter your comment!
Please enter your name here

This site uses Akismet to reduce spam. Learn how your comment data is processed.