# Time sheet for work

I have built a sheet to track time at work. It is very simple, there are 13 sheets, one for each month and a worksheet containing totals for each project.

The above picture shows you January 2017, simply enter the project name in column A and the hours in cell range B5:AF32. Row 4 contains dates for January, row 3 the weekdays, and row 2 the week numbers. Saturday and Sundays are colored grey.

**What's on this page**

## 1. How it works

The Summary sheet, see picture above, contains all projects entered in all month sheets and a total, both for the month and project. A quite large array formula extracts all project names in column B, you don't need to do that manually.

A simple SUMIF function sums the values from each monthly sheet, excel takes care of that too. There is no VBA in this workbook, you can find the get link at the end of this article.

If you change the year on sheet "Summary" you will notice that the monthly sheets change accordingly, you don't need to change weekdays, week number, or color weekends on each sheet, Excel will do it for you.

Any suggestions for improvement?

## 2. How I built this time tracker

The workbook has a summary sheet and sheets for each month in a year. The summary sheet allows you to enter the year in cell H1, I also changed the font size for that cell.

### 2.1 Building monthly sheets

The first monthly sheet is January, this sheet will be the template for the remaining months. This means I will copy this sheet and change the date for each sheet.

Cell D1 contains this formula: =Summary!H1

This lets you change the year on the summary sheet and all other monthly sheets will be instantly updated.

Formula in cell I1: =DATE(D1,1,1)

Select cell I1 and press CTRL + 1 to open the formatting cells dialog box. Change formatting category to "Custom".

Change Type to MMMM;@

If this is not working you need to find out your regional settings in Windows and change MMMM accordingly. This web page from Microsoft explains how to use the formatting dialog box.

This is what cell I1 now looks like:

Time to add dates,type 1 to 31 in cell range B4:AH4. I also change the cell width to 21 pixels. Type "Project" in cell A4, cells below contains project names.

Add text "Total:" to cell AG4 and use this formula in cell AG5:=SUM(B5:AF5)

Copy cell AG5 and paste to cell range AG6:AG32. See picture below.

Add text "Total:" to cell A33 and use this formula in cell B33:=SUM(B5:B32)

Copy cell A33 and paste to cell range B33:AF33. See picture above.

To make this sheet easier to read I want the row above dates to contain the abbreviation of days of the week. I am using this formula in cell B3:

I also want the row above days of the week to contain the week number. Formula in cell B2:

But I only want that number above a date when a new week starts.

Formula in cell C2:

Copy cell C2 and paste to D2:AF2. See pic below.

### 2.2 Highlight weekends

The following conditional formatting formula highlights weekends gray:

(WEEKDAY(B$4,2)>5)*(MONTH(B$4)=MONTH($B$4))

- Select cell range B4:AF32
- Go to tab Home on the ribbon
- Press with left mouse button on "Conditional Formatting" button and then press with left mouse button on "New Rule.."
- Press with left mouse button on "Use a formula to determine which cells to format"
- Paste above formula to field "Format values where this formula is true:"

- Press with left mouse button on "Format" button
- Go to tab "Fill"
- Pick a color

- Press with left mouse button on OK button

Worksheet "January" now looks like this:

The conditional formatting changes depending on what month and year it is, this is not something you have to manually do.

### 2.3 Grid pattern - Conditional Formatting

The next thing is the grid pattern, here is the conditional formatting formula:

=IF($AI$3="Off",,MONTH(B$4)=MONTH($B$4))

To build formatting formula, repeat above steps 1 to 8 except instead of picking a color, go to tab "Border" and press with left mouse button on "Outline, then press with left mouse button on the OK button. See the picture below.

### 2.4 Create remaining months

Worksheet January is now ready, time to copy the worksheet and create worksheets for the remaining months.

- Press with right mouse button on on the worksheet "January".
- Press with left mouse button on "Move or Copy...".
- Select "move to end" and "Create a copy".
- Press with left mouse button on the OK button.

Repeat above steps until you have a worksheet for each month in a year.

- Rename the sheet after January to February
- Change formula in cell I1 to =DATE(D1,2,1)

Note that February is the second month in a year and the second argument in the formula is then 2.

Repeat steps 1 and 2 above for all remaining worksheets.

### 2.5 Totals worksheet

Formula in cell B4:

### Explaining formula in cell B4

INDEX(Jan!$A$5:$A$32 , MATCH(0 , COUNTIF(Summary!$B$2:B3 , Jan!$A$5:$A$32&"") , 0))

#### Step 1 - Check previous values above the current cell

The COUNTIF function calculates the number of cells that is equal to a condition.

COUNTIF(*range*, *criteria*)

COUNTIF(Summary!$B$2:B3 , Jan!$A$5:$A$32&"")

becomes

COUNTIF({0;"Project"}, {"Sp-1002"; "TK-006"; "BR-4K3"; "DK-1001"; "GB-458"; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""})

and returns {0; 0; 0; 0; 0; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1}.

Note that the COUNTIF function also returns 1 for empty cells.

#### Step 2 - Find relative position of a not yet shown value

The MATCH function returns the relative position of an item in an array or cell reference that matches a specified value in a specific order.

MATCH(*lookup_value*, *lookup_array*, [*match_type*])

We are looking for values not yet displayted in cells above the current cell. 0 (zero) indicates it has not yet been shown.

MATCH(0 , COUNTIF(Summary!$B$2:B3 , Jan!$A$5:$A$32&"") , 0)

becomes

MATCH(0 , {0; 0; 0; 0; 0; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1; 1} , 0)

and returns 1.

#### Step 3 - Return value

The INDEX function returns a value from a cell range, you specify which value based on a row and column number.

INDEX(*array*, *[row_num]*, *[column_num]*)

INDEX(Jan!$A$5:$A$32 , MATCH(0 , COUNTIF(Summary!$B$2:B3 , Jan!$A$5:$A$32&"") , 0))

becomes

INDEX(Jan!$A$5:$A$32, 1)

becomes

INDEX({"Sp-1002"; "TK-006"; "BR-4K3"; "DK-1001"; "GB-458"; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""; ""}, 1)

and returns "Sp-1002" in cell B4.

#### Step 4 - Go to the next worksheet

The IFERROR function lets you use another formula when there are no more values to display. This behavior is called nested functions and is repeated to include all worksheets.

IFERROR(INDEX(Jan!$A$5:$A$32 , MATCH(0 , COUNTIF(Summary!$B$2:B3 , Jan!$A$5:$A$32&"") , 0)) , INDEX(Feb!$A$5:$A$32 , MATCH(0 , COUNTIF(Summary!$B$2:B3 , Feb!$A$5:$A$32&"") , 0)))

This article describes how to build a calendar showing all days in a chosen month with corresponding scheduled events. What's […]

Plot date ranges in a calendar part 2

I will in this article demonstrate a calendar that automatically highlights dates based on date ranges, the calendar populates names […]

Geoff asks: Hi Oscar, I have a cross reference table we use for shift scheduling. The x-axis is comprised of […]

Highlight specific time ranges in a weekly schedule

In a previous post I created a simple weekly schedule with dynamic dates, in this post I am going to […]

Count entries based on date and time

Question: My issue is that I get the date in this format: 7/23/2011 7:00:00 AM I am trying to count […]

Populate cells dynamically in a weekly schedule

In this post I am going to add one more function to the weekly schedule I built in a previous […]

The image above shows a calendar that is dynamic meaning you choose year and month and the calendar instantly updates […]

### 10 Responses to “Time sheet for work”

### Leave a Reply to Xiaoshan

### How to comment

**How to add a formula to your comment**

<code>Insert your formula here.</code>

**Convert less than and larger than signs**

Use html character entities instead of less than and larger than signs.

< becomes < and > becomes >

**How to add VBA code to your comment**

[vb 1="vbnet" language=","]

Put your VBA code here.

[/vb]

**How to add a picture to your comment:**

Upload picture to postimage.org or imgur

Paste image link to your comment.

**Contact Oscar**

You can contact me through this contact form

Lots of nice learning in this workbook, Oscar.

I will study it further and eventually comment it or ask you some questions.

GREAT!

Torstein Johnsen

Thank you.

There is a minor formula error in the summary sheet in row 3, showing "jun" three times. Just a copy error I suppose!

Torstein Johnsen

You are right, I have uploaded a new file and a new picture to this post.

Beautiful work! I definitely learnt something from it, thank you for sharing !

Xiaoshan

Thank you.

Hi Oscar

That's great job

I've just one comment, it this sheet is done for time absence for employees, then that's fine but if it is made to track projects, then it needs to add the target hours.

This sheet now shows me how many hours done for the project but this is meaning less since I don't know how much left over.

Hence, you may add in another column, target hours for completion.

Then you may also reflect this on a drawing chart showing for example a big arrow showing a green color for the completed hours and yellow color for remaining hours.

Regards.

Hi Dear

I have a question about the hours you entered in months, with the year change they will not go away. How you make them disappear year to year? Eg: if you enter 2 in Jan 01, 2018 & you change the year to 2019 the 2 you entered is still there

Dear Hector

I have a question about the hours you entered in months, with the year change they will not go away.Yes, this is a template. They don't disappear, you have to clear the cells manually.

Hi Oscar

Great template, I have a problem similar to the one you present, but I have an additional problem and that is, instead of having to know monthly totals, I have to know totals per week and the sum is between Monday and Friday. In the end, instead of having JAN - FEB - ... there would be W1 - W2 - W3 - ... - W53.

How would you do this?

Thanks