命名空间
变体
操作

std::get_time

来自 cppreference.cn
< cpp‎ | io‎ | 操纵器
 
 
 
输入/输出操纵器
浮点格式化
整数格式化
布尔格式化
字段宽度和填充控制
其他格式化
空白字符处理
输出刷新
(C++20)  

状态标志操作
时间与金钱 I/O
(C++11)
get_time
(C++11)
(C++11)
(C++11)
带引号的操纵器
(C++14)
 
定义于头文件 <iomanip>
template< class CharT >
/*未指定*/ get_time( std::tm* tmb, const CharT* fmt );
(C++11 起)

当在表达式 in >> get_time(tmb, fmt) 中使用时,根据输入流 in 中当前注入的区域设置的 std::time_get 面,将字符输入解析为符合格式字符串 fmt 的日期/时间值。结果值存储在由 tmb 指向的 std::tm 对象中。

目录

[编辑] 参数

tmb - 指向 std::tm 对象的有效指针,结果将存储在此处
fmt - 指向 null 终止的 CharT 字符串的指针,指定转换格式

格式字符串由零个或多个转换说明符、空白字符和普通字符(除了 %)组成。每个普通字符应与输入流中的一个字符进行大小写不敏感的匹配。每个空白字符匹配输入字符串中的任意空白。每个转换规范以 % 字符开头,可选地后跟 EO 修饰符(如果区域设置不支持则忽略),然后是确定说明符行为的字符。格式说明符与 POSIX 函数 strptime() 匹配

转换
说明符
解释 写入字段
% 匹配字面值 %。完整的转换规范必须是 %% (无)
t 匹配任何空白 (无)
n 匹配任何空白 (无)
Y 将完整的年份解析为 4 位十进制数,允许但不要求前导零 tm_year
EY 解析年份的替代表示,例如,在 ja_JP 区域设置中将 平成23年(平成 23 年)解析为 tm_year 中的 2011 tm_year
y 年份的最后 2 位解析为十进制数。范围 [69,99] 产生值 1969 到 1999,范围 [00,68] 产生值 2000-2068 tm_year
Oy 使用替代数字系统解析年份的最后 2 位,例如,在 ja_JP 区域设置中将 十一 解析为 11 tm_year
Ey 年份解析为与区域设置的替代日历周期 %EC 的偏移量 tm_year
C 年份的前 2 位解析为十进制数(范围 [00,99] tm_year
EC 解析区域设置替代表示中的基准年(时期)名称,例如,ja_JP 中的 平成(平成时代) tm_year
b 解析月份名称,可以是完整的或缩写的,例如 Oct tm_mon
h b 的同义词 tm_mon
B b 的同义词 tm_mon
m 月份解析为十进制数(范围 [01,12]),允许但不要求前导零 tm_mon
Om 使用替代数字系统解析月份,例如,在 ja_JP 区域设置中将 十二 解析为 12 tm_mon
U 年份中的周解析为十进制数(星期日是第一天)(范围 [00,53]),允许但不要求前导零 tm_year, tm_wday, tm_yday
OU 使用替代数字系统解析年份中的周,如 %U,例如,在 ja_JP 区域设置中将 五十二 解析为 52 tm_year, tm_wday, tm_yday
W 年份中的周解析为十进制数(星期一是第一天)(范围 [00,53]),允许但不要求前导零 tm_year, tm_wday, tm_yday
OW 使用替代数字系统解析年份中的周,如 %W,例如,在 ja_JP 区域设置中将 五十二 解析为 52 tm_year, tm_wday, tm_yday
年/月中的日
j 年份中的日解析为十进制数(范围 [001,366]),允许但不要求前导零 tm_yday
d 月份中的日解析为十进制数(范围 [01,31]),允许但不要求前导零 tm_mday
Od 使用替代数字系统解析月份中的日,例如,在 ja_JP 区域设置中将 二十七 解析为 27,允许但不要求前导零 tm_mday
e d 的同义词 tm_mday
Oe Od 的同义词 tm_mday
星期几
a 解析星期几的名称,可以是完整的或缩写的,例如 Fri tm_wday
A a 的同义词 tm_wday
w 工作日解析为十进制数,其中星期日是 0(范围 [0-6] tm_wday
Ow 工作日解析为十进制数,其中星期日是 0,使用替代数字系统,例如,在 ja_JP 区域设置中将 二 解析为 2 tm_wday
时、分、秒
H 小时解析为十进制数,24 小时制(范围 [00-23]),允许但不要求前导零 tm_hour
OH 使用替代数字系统从 24 小时制解析小时,例如,在 ja_JP 区域设置中将 十八 解析为 18 tm_hour
I 小时解析为十进制数,12 小时制(范围 [01,12]),允许但不要求前导零 tm_hour
OI 使用替代数字系统从 12 小时制解析小时,例如,在 ja_JP 区域设置中将 六 读取为 06 tm_hour
M 分钟解析为十进制数(范围 [00,59]),允许但不要求前导零 tm_min
OM 使用替代数字系统解析分钟,例如,在 ja_JP 区域设置中将 二十五 解析为 25 tm_min
S 解析为十进制数(范围 [00,60]),允许但不要求前导零 tm_sec
OS 使用替代数字系统解析,例如,在 ja_JP 区域设置中将 二十四 解析为 24 tm_sec
其他
c 解析区域设置的标准日期和时间字符串格式,例如 Sun Oct 17 04:41:13 2010(取决于区域设置) 所有
Ec 解析区域设置的替代日期和时间字符串格式,例如在 ja_JP 区域设置中期望 平成23年 (平成 23 年) 而不是 2011年 (2011 年) 所有
x 解析区域设置的标准日期表示 所有
Ex 解析区域设置的替代日期表示,例如在 ja_JP 区域设置中期望 平成23年 (平成 23 年) 而不是 2011年 (2011 年) 所有
X 解析区域设置的标准时间表示 所有
EX 解析区域设置的替代时间表示 所有
D 等同于 "%m / %d / %y " tm_mon, tm_mday, tm_year
r 解析区域设置的标准 12 小时制时间(在 POSIX 中,"%I : %M : %S %p" tm_hour, tm_min, tm_sec
R 等同于 "%H : %M" tm_hour, tm_min
T 等同于 "%H : %M : %S" tm_hour, tm_min, tm_sec
p 解析区域设置的 a.m. 或 p.m. 等效项 tm_hour

注意:tm_isdst 不会被写入,并且需要明确设置才能与 mktime 等函数一起使用


[编辑] 返回值

一个未指定类型的对象,使得

  • 如果 instd::basic_istream<CharT, Traits> 类型,则表达式 in >> get_time(tmb, fmt)
    • 类型为 std::basic_istream<CharT, Traits>&
    • 值为 in
    • 其行为如同调用了 f(in, tmb, fmt)

其中函数 f 定义为

template<class CharT, class Traits>
void f(std::basic_ios<CharT, Traits>& str, std::tm* tmb, const CharT* fmt)
{
    using Iter = std::istreambuf_iterator<CharT, Traits>;
    using TimeGet = time_get<CharT, Iter>;
 
    std::ios_base::iostate err = std::ios_base::goodbit;
    const TimeGet& tg = std::use_facet<TimeGet>(str.getloc());
 
    tg.get(Iter(str.rdbuf()), Iter(), str, err, tmb,
        fmt, fmt + Traits::length(fmt));
 
    if (err != std::ios_base::goodbit)
        str.setstate(err);
}

[编辑] 注意

根据此函数调用的 std::time_get::do_get 中指定,此函数是否将 *tmb 中未由 fmt 中出现的转换说明符直接设置的字段清零是未指定的:可移植程序应在调用 std::get_time 之前将 *tmb 的每个字段初始化为零。

[编辑] 示例

注意:选择 clang 或 gcc >= 12.1 以观察输出。12.1 之前的 libstdc++ 没有正确实现 %b 说明符:bug #78714

#include <iomanip>
#include <iostream>
#include <locale>
#include <sstream>
 
int main()
{
    std::tm t = {};
    std::istringstream ss("2011-Februar-18 23:12:34");
    ss.imbue(std::locale("de_DE.utf-8"));
    ss >> std::get_time(&t, "%Y-%b-%d %H:%M:%S");
 
    if (ss.fail())
        std::cout << "Parse failed\n";
    else
        std::cout << std::put_time(&t, "%c") << '\n';
}

可能的输出

Sun Feb 18 23:12:34 2011

[编辑] 参阅

从输入字符序列解析时间/日期值到 std::tm
(类模板) [编辑]
(C++11)
根据指定格式格式化并输出日期/时间值
(函数模板) [编辑]
(C++20)
从流解析 chrono 对象
(函数模板) [编辑]