std::formatter<std::chrono::duration>
在标头 <chrono> 定义 | ||
template<class Rep, class Period, class CharT > struct formatter<std::chrono::duration<Rep, Period>, CharT>; | ||
std::formatter 的特化,定义 std::chrono::duration 的格式化规则。duration
被判读为自午夜起经过的时间。
通常不直接访问,但通过格式化函数使用 std::formatter 特化。
[编辑]格式说明
格式说明拥有形式
填充与对齐 (可选)宽度 (可选)精度 (可选)L (可选)时间说明 (可选) | |||||||||
填充与对齐、宽度 及精度拥有同标准格式说明中的含义。精度 仅对表示类型 Rep
是浮点类型的 std::chrono::duration 类型合法,否则抛出 std::format_error。
用于格式化的本地环境确定如下:
- 在格式说明中不存在
L
时是默认的 "C" 本地环境, - 否则,在有传递给格式化函数的 std::locale 时是它代表的本地环境,
- 否则(
L
存在但无传递给格式化函数的 std::locale)是全局本地环境。
如果(通常或宽)字符串字面量编码为 Unicode 编码形式且本地环境在一个实现定义的本地环境集合中,则如同将替换字符序列转换到该字面量编码一般,进行每个取决于本地环境的替换。
时间说明 由一或更多个转换说明符与(除了 {
、}
与 %
外的)普通字符构成。时间说明 必须始于一个转换说明符。所有普通字符均不修改地写入到输出。每个无修饰的转换说明符始于 %
字符后随一个确定说明符行为的字符。某些转换说明符拥有修饰形式,其中将 E
或 O
修饰字符插入到 %
字符之后。按描述于下的方式以适合的字符替换每个转换说明符。
除非另有说明,如果时间说明 为空,那么时间对象的格式化,如同将该对象流化到 std::stringstream 类型的对象 os
,它的浸染了格式化本地环境(std::locale::classic()、传递的 std::locale 对象或 std::locale::global() 之一),后复制 os.str() 到输出缓冲,附带按照各格式说明符进行的填充和调整。
下列格式说明符可用:
转换说明符 | 解释 | |
---|---|---|
%% | 写字面的 % 字符。 | |
%n | 写换行符。 | |
%t | 写水平制表符。 | |
当天时刻 | ||
%H %OH | 按十进制数字写时(24 小时时钟)。若结果为单个数位,则前附 0。 修饰的命令 | |
%I %OI | 按十进制数字写时(12 小时时钟)。若结果为单个数位,则前附 0。 修饰的命令 | |
%M %OM | 按十进制数字写分。若结果为单个数位,则前附 0。 修饰的命令 | |
%S %OS | 按十进制数字写秒。若结果为单个数位,则前附 0。 若输入的精度不能以秒精确表示,则格式为 fixed 格式且精度匹配输入精度的十进制浮点数(或若不能在 18 位小数内转换到浮点数十进制秒,则为到微秒精度)。用作小数点的字符按照本地环境本地化。 修饰的命令 | |
%p | 写与 12 小时时钟相关的 AM/PM 设计的本地环境版本。 | |
%R | 等价于 "%H:%M" 。 | |
%T | 等价于 "%H:%M:%S" 。 | |
%r | 写本地环境的 12 小时时钟时间。 | |
%X %EX | 写本地环境的时间表示。 修饰的命令 | |
时长计数 | ||
%Q | 写时长的计次数,即经由 count() 获得的值。 | |
%q | 写 operator<<() 中指定的时长单位后缀。 |
下列说明符得到辨识,但会导致抛出 std::format_error :
转换 说明符 | 解释 | |
---|---|---|
年 | ||
%C %EC | 写年除以 100 向下取整的结果。若结果为单个十进制位,则前附 0。 修饰的命令 | |
%y %Oy %Ey | 写年的末二位十进制数。若结果为单个数位,则前附 0。 修饰的命令 修饰的命令 | |
%Y %EY | 按十进制数写年。若结果少于四位,则左填充 0 到四位。 修饰的命令 | |
月 | ||
%b %h | 写本地环境的缩写月名。 | |
%B | 写本地环境的完整月名。 | |
%m %Om | 按十进制数写月份(一月为 01 )。若结果为单个数位,则前附 0。 修饰的命令 | |
日 | ||
%d %Od | 按十进制数写月之日。若结果为单个十进制位,则前附 0。 修饰的命令 | |
%e %Oe | 按十进制数写月之日。若结果为单个十进制位,则前附空格。 修饰的命令 | |
星期之日 | ||
%a | 写本地环境的缩写星期名。 | |
%A | 写本地环境的完整星期名。 | |
%u %Ou | 按十进制数写 ISO 星期之日(1-7),其中星期一为 1 。 修饰的命令 | |
%w %Ow | 写星期之日为十进制数(0-6),其中星期日为 0 。 修饰的命令 | |
ISO 8601 基于星期的年 | ||
ISO 8601 星期始于星期一而年的第一星期必须满足下列要求:
| ||
%g | 写 ISO 8601 基于星期的年的后二位十进制数。若结果为单个数位,则前附 0。 | |
%G | 按十进制数写 ISO 8601 基于星期的年。若结果少于四位,则左填充 0 到四位。 | |
%V %OV | 按十进制数年的 ISO 8601 星期。若结果为单个数位,则前附 0。 修饰的命令 | |
年之星期/日 | ||
%j | 按十进制数写年的日(1 月 1 日为 001 )。若结果少于三位,则左填充 0 到三位。 | |
%U %OU | 按十进制数写年的星期数。该年的首个星期日为 01 星期的首日。同年中之前的日在 00 星期中。若结果为单个数位,则前附 0。 修饰的命令 | |
%W %OW | 按十进制数写年的星期数。该年的首个星期一为 01 星期的首日。同年中之前的日在 00 星期中。若结果为单个数位,则前附 0。 修饰的命令 | |
日期 | ||
%D | 等价于 "%m/%d/%y" 。 | |
%F | 等价于 "%Y-%m-%d" 。 | |
%x %Ex | 写本地环境的日期表示。 修饰的命令 | |
时区 | ||
%z %Ez %Oz | 以 ISO 8601 格式写自 UTC 的偏移。例如 -0430 表示 UTC 后 4 小时 30 分。若偏移为 0,则使用 +0000 。 修饰的命令 | |
%Z | 写时区缩写。 | |
杂项 | ||
%c %Ec | 写本地环境的日期与时间表示。 修饰的命令 |
[编辑]示例
#include <chrono>#include <print>usingnamespace std::chrono_literals; int main(){auto du{3h + 2min + 1s}; std::print("时长为:\n""{}\n""{:%T}\n""{:%H:%M:%S}\n""{:%H 时 %M 分 %S 秒}\n", du, du, du, du);}
可能的输出:
时长为: 10921s 03:02:01 03:02:01 03 时 02 分 01 秒
[编辑]参阅
(C++20) | 在新字符串中存储参数的格式化表示 (函数模板) |