Mwnci asctime() Function

Syntax

asctime(seconds, format)

Description

The asctime() function returns the formatted date/time of seconds since 1970-01-01 00:00:00 UTC.

If format is given, asctime() returns the date/time strings in the specified format.

If no format is given, the a default of “%a %b %d %H:%M:%S %Y” is used.

Format

Date (Year, Month, Day):

 %Y - Year with century (can be negative, 4 digits at least)
         -0001, 0000, 1995, 2009, 14292, etc.
 %C - year / 100 (round down, 20 in 2009)
 %y - year % 100 (00..99)
 %m - Month of the year, zero-padded (01..12)
         %-m  no-padded (1..12)
 %B - Full month name (January)
 %b - Abbreviated month name (Jan)
 %h - Equivalent to %b
 %d - Day of the month, zero-padded  (01..31)
         %-d  no-padded (1..31)
 %e - Day of the month, blank-padded ( 1..31)
 %j - Day of the year (001..366)
         %-j  no-padded (1..366)

Time (Hour, Minute, Second, Subsecond):

 %H - Hour of the day, 24-hour clock, zero-padded  (00..23)
         %-H  no-padded (0..23)
 %k - Hour of the day, 24-hour clock, blank-padded ( 0..23)
 %I - Hour of the day, 12-hour clock, zero-padded  (01..12)
         %-I  no-padded (1..12)
 %l - Hour of the day, 12-hour clock, blank-padded ( 1..12)
 %P - Meridian indicator, lowercase (am or pm)
 %p - Meridian indicator, uppercase (AM or PM)
 %M - Minute of the hour (00..59)
         %-M  no-padded (0..59)
 %S - Second of the minute (00..60)
         %-S  no-padded (0..60)
 %L - Millisecond of the second (000..999)
 %f - Microsecond of the second (000000..999999)
 %N - Nanosecond  of the second (000000000..999999999)

Time zone:

 %z - Time zone as hour and minute offset from UTC (e.g. +0900)
         %:z - hour and minute offset from UTC with a colon (e.g. +09:00)
 %Z - Time zone abbreviation (e.g. MST)

Weekday:

 %A - Full weekday name (Sunday)
 %a - Abbreviated weekday name (Sun)
 %u - Day of the week (Monday is 1, 1..7)
 %w - Day of the week (Sunday is 0, 0..6)

ISO 8601 week-based year and week number: Week 1 of YYYY starts with a Monday and includes YYYY-01-04. The days in the year before the first week are in the last week of the previous year.

 %G - Week-based year
 %g - Last 2 digits of the week-based year (00..99)
 %V - Week number of the week-based year (01..53)
         %-V  no-padded (1..53)

Week number: Week 1 of YYYY starts with a Sunday or Monday (according to %U or %W). The days in the year before the first week are in week 0.

 %U - Week number of the year.  The week starts with Sunday.  (00..53)
         %-U  no-padded (0..53)
 %W - Week number of the year.  The week starts with Monday.  (00..53)
         %-W  no-padded (0..53)

Seconds since the Unix Epoch:

 %s - Number of seconds since 1970-01-01 00:00:00 UTC.
 %Q - Number of milliseconds since 1970-01-01 00:00:00 UTC.

Literal string:

 %n - Newline character (\n)
 %t - Tab character (\t)
 %% - Literal % character

Combination:

 %c - date and time (%a %b %e %T %Y)
 %D - Date (%m/%d/%y)
 %F - ISO 8601 date format (%Y-%m-%d)
 %v - VMS date (%e-%b-%Y)
 %x - Same as %D
 %X - Same as %T
 %r - 12-hour time (%I:%M:%S %p)
 %R - 24-hour time (%H:%M)
 %T - 24-hour time (%H:%M:%S)
 %+ - date(1) (%a %b %e %H:%M:%S %Z %Y)

Example

raw_time=time()
default_output=asctime(raw_time)
printf("raw time is %d, default asctime() output is %s\n", raw_time, default_output)
output_with_format=asctime(raw_time, "Day is %A, Month is %B, Time is %X, Timezone is %Z")
printf("%s\n", output_with_format)


raw time is 1669923810, default asctime() output is Thu Dec 01 19:43:30 2022
Day is Thursday, Month is December, Time is 19:43:30, Timezone is GMT