The format string consists of zero or more conversion specifiers and ordinary characters (except %). All ordinary characters, including the terminating null character, are copied to the output string without modification. Each conversion specification begins with % character, optionally followed by E or O modifier (ignored if unsupported by the locale), followed by the character that determines the behavior of the specifier. The following format specifiers are available:
Conversion specifier
|
Explanation
|
Used fields
|
%
|
writes literal %. The full conversion specification must be %%.
|
|
n(C++11)
|
writes newline character
|
|
t(C++11)
|
writes horizontal tab character
|
|
Year
|
Y
|
writes year as a 4 digit decimal number
|
tm_year
|
EY(C++11)
|
writes year in the alternative representation, e.g.平成23年 (year Heisei 23) instead of 2011年 (year 2011) in ja_JP locale
|
tm_year
|
y
|
writes last 2 digits of year as a decimal number (range [00,99])
|
tm_year
|
Oy(C++11)
|
writes last 2 digits of year using the alternative numeric system, e.g. 十一 instead of 11 in ja_JP locale
|
tm_year
|
Ey(C++11)
|
writes year as offset from locale's alternative calendar period %EC (locale-dependent)
|
tm_year
|
C(C++11)
|
writes first 2 digits of year as a decimal number (range [00,99])
|
tm_year
|
EC(C++11)
|
writes name of the base year (period) in the locale's alternative representation, e.g. 平成 (Heisei era) in ja_JP
|
tm_year
|
G(C++11)
|
writes ISO 8601 week-based year, i.e. the year that contains the specified week.
In IS0 8601 weeks begin with Monday and the first week of the year must satisfy the following requirements:
- Includes January 4
- Includes first Thursday of the year
|
tm_year, tm_wday, tm_yday
|
g(C++11)
|
writes last 2 digits of ISO 8601 week-based year, i.e. the year that contains the specified week (range [00,99]).
In IS0 8601 weeks begin with Monday and the first week of the year must satisfy the following requirements:
- Includes January 4
- Includes first Thursday of the year
|
tm_year, tm_wday, tm_yday
|
Month
|
b
|
writes abbreviated month name, e.g. Oct (locale dependent)
|
tm_mon
|
h(C++11)
|
synonym of b
|
tm_mon
|
B
|
writes full month name, e.g. October (locale dependent)
|
tm_mon
|
m
|
writes month as a decimal number (range [01,12])
|
tm_mon
|
Om(C++11)
|
writes month using the alternative numeric system, e.g. 十二 instead of 12 in ja_JP locale
|
tm_mon
|
Week
|
U
|
writes week of the year as a decimal number (Sunday is the first day of the week) (range [00,53])
|
tm_year, tm_wday, tm_yday
|
OU(C++11)
|
writes week of the year, as by %U, using the alternative numeric system, e.g. 五十二 instead of 52 in ja_JP locale
|
tm_year, tm_wday, tm_yday
|
W
|
writes week of the year as a decimal number (Monday is the first day of the week) (range [00,53])
|
tm_year, tm_wday, tm_yday
|
OW(C++11)
|
writes week of the year, as by %W, using the alternative numeric system, e.g. 五十二 instead of 52 in ja_JP locale
|
tm_year, tm_wday, tm_yday
|
V(C++11)
|
writes ISO 8601 week of the year (range [01,53]).
In IS0 8601 weeks begin with Monday and the first week of the year must satisfy the following requirements:
- Includes January 4
- Includes first Thursday of the year
|
tm_year, tm_wday, tm_yday
|
OV(C++11)
|
writes week of the year, as by %V, using the alternative numeric system, e.g. 五十二 instead of 52 in ja_JP locale
|
tm_year, tm_wday, tm_yday
|
Day of the year/month
|
j
|
writes day of the year as a decimal number (range [001,366])
|
tm_yday
|
d
|
writes day of the month as a decimal number (range [01,31])
|
tm_mday
|
Od(C++11)
|
writes zero-based day of the month using the alternative numeric system, e.g 二十七 instead of 23 in ja_JP locale
Single character is preceded by a space.
|
tm_mday
|
e(C++11)
|
writes day of the month as a decimal number (range [1,31]).
Single digit is preceded by a space.
|
tm_mday
|
Oe(C++11)
|
writes one-based day of the month using the alternative numeric system, e.g. 二十七 instead of 27 in ja_JP locale
Single character is preceded by a space.
|
tm_mday
|
Day of the week
|
a
|
writes abbreviated weekday name, e.g. Fri (locale dependent)
|
tm_wday
|
A
|
writes full weekday name, e.g. Friday (locale dependent)
|
tm_wday
|
w
|
writes weekday as a decimal number, where Sunday is 0 (range [0-6])
|
tm_wday
|
Ow(C++11)
|
writes weekday, where Sunday is 0, using the alternative numeric system, e.g. 二 instead of 2 in ja_JP locale
|
tm_wday
|
u(C++11)
|
writes weekday as a decimal number, where Monday is 1 (ISO 8601 format) (range [1-7])
|
tm_wday
|
Ou(C++11)
|
writes weekday, where Monday is 1, using the alternative numeric system, e.g. 二 instead of 2 in ja_JP locale
|
tm_wday
|
Hour, minute, second
|
H
|
writes hour as a decimal number, 24 hour clock (range [00-23])
|
tm_hour
|
OH(C++11)
|
writes hour from 24-hour clock using the alternative numeric system, e.g. 十八 instead of 18 in ja_JP locale
|
tm_hour
|
I
|
writes hour as a decimal number, 12 hour clock (range [01,12])
|
tm_hour
|
OI(C++11)
|
writes hour from 12-hour clock using the alternative numeric system, e.g. 六 instead of 06 in ja_JP locale
|
tm_hour
|
M
|
writes minute as a decimal number (range [00,59])
|
tm_min
|
OM(C++11)
|
writes minute using the alternative numeric system, e.g. 二十五 instead of 25 in ja_JP locale
|
tm_min
|
S
|
writes second as a decimal number (range [00,60])
|
tm_sec
|
OS(C++11)
|
writes second using the alternative numeric system, e.g. 二十四 instead of 24 in ja_JP locale
|
tm_sec
|
Other
|
c
|
writes standard date and time string, e.g. Sun Oct 17 04:41:13 2010 (locale dependent)
|
all
|
Ec(C++11)
|
writes alternative date and time string, e.g. using 平成23年 (year Heisei 23) instead of 2011年 (year 2011) in ja_JP locale
|
all
|
x
|
writes localized date representation (locale dependent)
|
all
|
Ex(C++11)
|
writes alternative date representation, e.g. using 平成23年 (year Heisei 23) instead of 2011年 (year 2011) in ja_JP locale
|
all
|
X
|
writes localized time representation (locale dependent)
|
all
|
EX(C++11)
|
writes alternative time representation (locale dependent)
|
all
|
D(C++11)
|
equivalent to "%m/%d/%y"
|
tm_mon, tm_mday, tm_year
|
F(C++11)
|
equivalent to "%Y-%m-%d" (the ISO 8601 date format)
|
tm_mon, tm_mday, tm_year
|
r(C++11)
|
writes localized 12-hour clock time (locale dependent)
|
tm_hour, tm_min, tm_sec
|
R(C++11)
|
equivalent to "%H:%M"
|
tm_hour, tm_min
|
T(C++11)
|
equivalent to "%H:%M:%S" (the ISO 8601 time format)
|
tm_hour, tm_min, tm_sec
|
p
|
writes localized a.m. or p.m. (locale dependent)
|
tm_hour
|
z(C++11)
|
writes offset from UTC in the ISO 8601 format (e.g. -0430), or no characters if the time zone information is not available
|
tm_isdst
|
Z
|
writes time zone name or abbreviation, or no characters if the time zone information is not available (locale dependent)
|
tm_isdst
|