utime – Time functions

Differences to CPython

This module implements a subset of the corresponding CPython 3.5 module, as described below. For more information, refer to the original CPython documentation: time (version 3.5).

This module is used when executing on SR OS only. On a remote machine, the native Python time module is used.

The utime module provides functions for getting the current time and date, measuring time intervals, and for delays.



Convert a time, expressed in seconds, since the epoch to a struct_time. If secs is not provided or None, the current time is returned by time(). Fractions of a second are ignored.


secs (int, optional) – Seconds since epoch. Default None


Structured time object in UTC where the dst flag is 0.

Return type



Operates like gmtime() but converts to the local time. The local time is defined by the timezone configured on SR OS in the /configure system time zone context.


secs (int, optional) – Seconds since epoch. Default None


Structured time object in local time. The dst flag is set to 1 when DST applies to the given time.

Return type



This is the inverse function of localtime(). The earliest date for which it can generate a time on SR OS is the epoch.


t (.struct_time, tuple(tm_year, tm_mon, tm_mday, tm_hour, tm_min, tm_sec, tm_wday, tm_yday, tm_isdst)) – Time in local time, not UTC. The dst flag is required; use -1 as the dst flag value if it is unknown.


Floating point number compatible with time(). If the input value cannot be represented as a valid time, either OverflowError or ValueError is raised (depending on whether the invalid value is caught by Python or the underlying C libraries).

Return type


  • OverflowError – Result of an arithmetic operation is too large to be represented.

  • ValueError – Argument has the right type but an inappropriate value, and the situation is not described by a more precise exception.


Suspend execution for the given period of time. The suspension time may be longer than requested by an arbitrary amount because of the scheduling of other activities in the system.

  • secs (int, float) – Time, in seconds.

  • millisecs (int, float) – Time, in milliseconds.

  • microsecs (int, float) – Time, in microseconds.

utime.strftime(format, t)

Convert a tuple or struct_time representing a time as returned by gmtime() or localtime() to a string as specified by the format argument. If t is not provided, the current time as returned by localtime() is used.

  • format (str) – Output format template. Accepted directives for the template can be found in the table below Format directives.

  • t (struct_time, tuple, optional) – Time


Formatted string

Return type



ValueError – Any field in t is outside of the allowed range.


0 is a valid input for any position in the time tuple. If the value is invalid, the value is changed to a correct one.

The following directives can be embedded in the format string. They are shown without the optional field width and precision specification, and are replaced by the indicated characters in the strftime() result.

Format directives





Abbreviated weekday name in English.



Weekday name in English.


Abbreviated month name in English.


Full month name in English.


Date and time representation.


Day of the month as a decimal number [Range: 01-31].


Hour (24-hour clock) as a decimal number [Range: 00-23].


Hour (12-hour clock) as a decimal number [Range: 01-12].


Day of the year as a decimal number [Range: 001-366].


Month as a decimal number [Range: 01-12].


Minute as a decimal number [Range: 00-59].


AM or PM.


Second as a decimal number [Range: 00-59].


Week number of the year (Sunday as the first day of the week) as a decimal number [Range: 00-53]. All days in a new year preceding the first Sunday are considered to be in week 0.


Weekday as a decimal number [Range: 0-6]. 0 is considered to mean Sunday.


Week number of the year (Monday as the first day of the week) as a decimal number [Range: 00-53]. All days in a new year preceding the first Monday are considered to be in week 0.


Locale’s appropriate date representation.


Locale’s appropriate time representation.


Year without century as a decimal number [Range: 00-99].


Year with century as a decimal number.


A literal '%' character.



Output uses English words and is all uppercase characters.

Example to format a date and time into RFC 2822 Internet email standard:

strftime() example
>>> from time import gmtime, strftime
>>> strftime("%a, %d %b %Y %H:%M:%S +0000", gmtime())
'THU, 28 JUN 2001 14:17:15 +0000'
class utime.struct_time

The type of the time value sequence returned by gmtime() and localtime(). It is an object with a named tuple interface. Values can be accessed by index or by attribute name.

When a tuple with an incorrect length is passed to a function expecting a struct_time, or has elements of the wrong type, a TypeError is raised. The following values are present:

struct_time object values






Example: 1993



[Range: 1-12] 2



[Range: 1-31]



[Range: 0-23]



[Range: 0-59]



[Range: 0-59]



[Range: 0-6]. Monday is 0



[Range: 1-366]



0, 1 or -1 3



Abbreviation of timezone name



Offset east of UTC in seconds



Note that unlike the C structure, the month value is a range of 1-12, not 0-11.


In calls to mktime(), tm_isdst may be set to 1 when daylight savings time is in effect, and 0 when it is not. A value of -1 indicates that this is not known, and results in the correct state being filled in.


Return an increasing millisecond counter with an arbitrary reference point, that wraps around after some value.

The wraparound value is not explicitly exposed, but for discussion, is referred to as TICKS_MAX. Period of the values is TICKS_PERIOD = TICKS_MAX + 1. TICKS_PERIOD is guaranteed to be a power of two, but otherwise may differ.

The same period value is used for all of ticks_ms(), ticks_us(), ticks_cpu() functions (for simplicity). Therefore, these functions return a value in the range [0 .. TICKS_MAX], inclusive, total TICKS_PERIOD values.

Values returned by these functions should be treated as opaque. The only operations available are ticks_diff() and ticks_add().


Increasing millisecond counter with an arbitrary reference point.

Return type



Note that only non-negative values are used.


Standard mathematical operations (e.g. +, -), or relational operators (e.g. <, <=, >, >=) cannot be performed directly on these values. Invalid results also occur if results from mathematical operations are passed as arguments to ticks_diff() or ticks_add().


Similar to ticks_ms() , but in microseconds.


Increasing microseconds counter with an arbitrary reference point.

Return type



Similar to ticks_ms() and ticks_us, but with the highest possible resolution in the system.


Increasing counter with an arbitrary reference point.

Return type


utime.ticks_add(ticks, delta)

Offset the value of ticks by a given (positive or negative) delta.

Given a ticks value, this function calculates the ticks value delta ticks before or after it, using the modular-arithmetic definition of tick values (see ticks_ms()).

ticks_add() is useful for calculating deadlines for events/tasks.

  • ticks (int) – ticks value as a direct result of a call to ticks_ms(), ticks_us() or ticks_cpu() or from a previous call to ticks_add().

  • delta (int, expr) – Positive or negative integer number or numeric expression.


Calculated value of ticks.

Return type



Use ticks_diff() function to work with deadlines.


  # Find out what ticks value 100ms ago
  print(ticks_add(time.ticks_ms(), -100))

  # Calculate deadline for operation and test for it
  deadline = ticks_add(time.ticks_ms(), 200)
  while ticks_diff(deadline, time.ticks_ms()) > 0:

  # Find out TICKS_MAX used by this port
  print(ticks_add(0, -1))
utime.ticks_diff(ticks1, ticks2)

Measure ticks difference between values returned from ticks_ms(), ticks_us(), or ticks_cpu() functions, as a signed value which may wrap around. The function has the same meaning as ticks1 - ticks2.

Values returned by ticks_ms(), ticks_us() or ticks_cpu() may wrap around. Directly using a subtraction operation produces an incorrect result. Use the ticks_diff() function provided.

The function implements modular (or more specifically, ring) arithmetic to produce the correct result, even for wraparound values (as long as there is not too much of a difference between them).

If the result is negative, it means that ticks1 occurred earlier in time than ticks2. Otherwise, it means that ticks1 occurred after ticks2. This holds only if ticks1 and ticks2 are apart from each other for no more than TICKS_PERIOD/2-1 ticks. If that does not hold, an incorrect result is returned. That is, if two tick values are apart for TICKS_PERIOD/2-1 ticks, that value is returned by the function. However, if TICKS_PERIOD/2 of real-time ticks has passed between them, the function returns -TICKS_PERIOD/2 instead. That is, the result value wraps to the negative range of possible values.


Signed value in the range [-TICKS_PERIOD/2 .. TICKS_PERIOD/2-1], which is a typical range definition for a two’s-completment signed binary integer.

Return type

int (signed)


Do not pass time() values to ticks_diff(). Use standard mathematical operations instead.


Return the time in seconds since the epoch.

The number returned by time() may be converted to a more common time format (i.e. year, month, day, hour, etc…) in UTC by passing it to gmtime() function, or in local time by passing it to the localtime() function. In both cases, a struct_time object is returned, from which the components of the calendar date may be accessed as attributes.


Time in seconds since the epoch.

Return type



Reset the time conversion rules used by the library routines. When invoked, the current time configuration is inspected and the variables tzname , timezone (non-DST seconds West of UTC), altzone (DST seconds west of UTC) and daylight are set. daylight is set to 0 if the timezone does not have daylight saving time rules, or to nonzero if there is a time (past, present or future) when daylight saving time applies.

Timezone constants


The offset of the local DST timezone, in seconds, west of UTC (if one is defined). The offset is negative if the local DST timezone is east of UTC (such as Western Europe, including the UK). Only use this if daylight is nonzero. See the note on timezone constants.


Nonzero if a DST timezone is defined. See the note on timezone constants.


The offset of the local (non-DST) timezone, in seconds, west of UTC (negative in most of Western Europe, positive in the USA, zero in the UK). See the note on timezone constants.


A tuple of two strings:

  • Name of the local non-DST timezone

  • Name of the local DST timezone

If no DST timezone is defined, the second string should not be used. See the note on timezone constants.


For the above timezone constants (altzone, daylight, timezone, and tzname), the value is determined by the timezone configuration in effect at module load time or the last time tzset() is called, and may be incorrect for times in the past. Nokia recommends using the tm_gmtoff and tm_zone results from localtime() to obtain timezone information.


The epoch on Nokia SR OS is January 1, 1970, 00:00:00 (UTC). Leap seconds are not counted towards the time in seconds since the epoch. This is commonly referred to as UNIX time.