Please Note: This article is written for users of the following Microsoft Excel versions: 2007, 2010, 2013, 2016, 2019, and Excel in Microsoft 365. If you are using an earlier version (Excel 2003 or earlier), this tip may not work for you. For a version of this tip written specifically for earlier versions of Excel, click here: Dealing with Large Numbers of Seconds.
Written by Allen Wyatt (last updated August 26, 2024)
This tip applies to Excel 2007, 2010, 2013, 2016, 2019, and Excel in Microsoft 365
Piers has a report which runs and once it is complete, he logs the start time and duration, in seconds. If A1 is the start time and B1 is the number of seconds, Piers uses the following formula to determine the ending time:
=A1+TIME(0,0,B1)
The formula works fine, unless report execution took over 32,767 seconds, which often happens. Piers wonders what formula he can use to get past this apparent Excel limitation.
First, it is important to understand that what you have discovered is, indeed, a limitation of Excel. Or, more precisely, a limitation of the TIME function. The three parameters you use in the function (representing hours, minutes, and seconds) must be integer values. That is "programming speak" for the fact that each value must be in the range of 0 to 32767. Outside that range, and you get an error.
One solution is to simply make sure that you don't use a value that is outside of this range. I like this recasting of the formula, still using the TIME function:
=A1+TIME(INT(B1/3600),0,MOD(B1,3600))
Whereas the limit in your original formula meant that you could not have a report run for much more than 9 hours (32767 seconds), this revised formula will handle durations of nearly 4 years. (If you have reports that are taking more than 4 years to run, something is probably wrong!)
Of course, you could bypass using the TIME function altogether and simply come up with your own formula to add the seconds to the value in A1. This is easier than it may seem; all you need to do is remember that time values are stored, within Excel, as fractions of a day. Since there are 86,400 seconds in each day (60 seconds * 60 minutes * 24 hours), you could use this formula:
=A1+B1/86400
Just make sure that the cell containing the formula is formatted to display times, and you'll have no problem. (Just format the cell the same way that cell A1 is formatted; you can use the Format Painter to do this.)
ExcelTips is your source for cost-effective Microsoft Excel training. This tip (9421) applies to Microsoft Excel 2007, 2010, 2013, 2016, 2019, and Excel in Microsoft 365. You can find a version of this tip for the older menu interface of Excel here: Dealing with Large Numbers of Seconds.
Create Custom Apps with VBA! Discover how to extend the capabilities of Office 2013 (Word, Excel, PowerPoint, Outlook, and Access) with VBA programming, using it for writing macros, automating Office applications, and creating custom applications. Check out Mastering VBA for Office 2013 today!
Excel worksheets can be used to keep track of all sorts of information. You may want to use it, for instance, to track ...
Discover MoreWhen using Excel to calculate elapsed time, there can be all sorts of criteria that affect the formulas you would ...
Discover MoreEntering the current time into a cell is easy, as Excel provides a built-in shortcut to accomplish the task. Here's a ...
Discover MoreFREE SERVICE: Get tips like this every week in ExcelTips, a free productivity newsletter. Enter your address and click "Subscribe."
2019-08-15 16:03:23
This saved my life on a project!!! Thank you!!!
2019-06-01 10:52:21
Ian Norman
This is great for times that can be expressed as integers in the range -32768 to 32676, but there are many circumstances where the time-value has to be expressed as a real number, e.g. seconds-past-midnight with a resolution of microseconds or even smaller. The problem that then arises is that it's easy to exceed even the range of real numbers, which - certainly in the past, e.g. with Excel 2007 and earlier - was limited to 56 bits. I handled this by importing very large numbers as text, and then manipulating the text, e.g. by first extracting the seconds-component into one cell, and then the residue into another. It was clunky, but I +was+ able to get to nanosecond-level resolution, which was just barely acceptable for scientific measurements such as the state-time changes of electronic components.
Got a version of Excel that uses the ribbon interface (Excel 2007 or later)? This site is for you! If you use an earlier version of Excel, visit our ExcelTips site focusing on the menu interface.
FREE SERVICE: Get tips like this every week in ExcelTips, a free productivity newsletter. Enter your address and click "Subscribe."
Copyright © 2025 Sharon Parq Associates, Inc.
Comments