std::get_time

来自cppreference.com
< cpp‎ | io‎ | manip
 
 
 
输入/输出操纵符
浮点格式化
整数格式化
布尔格式化
域宽与填充控制
其他格式化
空白符处理
输出冲入
状态标志操纵
时间与金钱 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) 时,按照格式字符串 fmt 及输入流 in 中当前浸染的本地环境的 std::time_get 刻面,分析字符输入为日期/时间值。将结果存储到 tmb 指向的 std::tm 对象中。

参数

tmb-指向 std::tm 对象的合法指针,将结果存储到它指向的对象中
fmt-指向指定转换格式的空终止 CharT 字符串的指针

格式字符串由零或更多转换说明符、空白字符和普通字符(除了 %)组成。期待每个普通字符按大小写无关比较匹配输入流中的一个字符。每个空白字符匹配输入字符串中的任意空白字符。每个转换说明都始于 % 字符,可选地后随 EO 修饰符(若本地环境不支持则忽略),后随确定说明符转换行为的字符。格式说明符与 POSIX 函数 strptime() 匹配:

转换说明符解释写入域
%匹配字面 %。完整转换说明必须是 %%(无)
t匹配任何空白符。(无)
n匹配任何空白符。(无)
Y分析完整为四位十进制数,容许但不要求前导零tm_year
EY以替代表示分析,例如 平成23年 在 ja_JP 本地环境中将 2011 写入 tm_yeartm_year
y分析的后二位为十进制数。范围 [69,99] 生成 1969 至 1999 的值,范围 [00,68] 生成 2000-2068tm_year
Oy以替代数值系统分析的后二位数字,例如 十一 在 ja_JP 本地环境中被分析为 11tm_year
Ey分析为从本地环境的替代日历时期 %EC 的偏移tm_year
C分析的首 2 位数字为十进制数(范围 [00,99]tm_year
EC分析本地环境的替代表示中,年号(时期)的名称,例如 ja_JP 中的 平成tm_year
b分析月份名,完整或缩写,例如 Octtm_mon
hb 的同义词tm_mon
Bb 的同义词tm_mon
m分析为十进制数(范围 [01,12]),容许但不要求前导零tm_mon
Om用替代数值系统分析,例如 ja_JP 本地环境中 十二 分析为 12tm_mon
星期
U分析年之星期为十进制数(星期日是星期的首日)(范围 [00,53]),容许但不要求前导零tm_year, tm_wday, tm_yday
OU用替代数值系统,如以 %U 一般分析年之星期,例如 ja_JP 本地环境中 五十二 分析为 52tm_year, tm_wday, tm_yday
W分析年之星期为十进制数(星期一是星期的首日)(范围 [00,53]),容许但不要求前导零tm_year, tm_wday, tm_yday
OW用替代数值系统,如以 %W 一般分析年之星期,例如 ja_JP 本地环境中 五十二 分析为 52tm_year, tm_wday, tm_yday
年/月之日
j分析年之日为十进制数(范围 [001,366]),容许但不要求前导零tm_yday
d分析月之日为十进制数(范围 [01,31]),容许但不要求前导零tm_mday
Od用替代数值系统分析月之日,例如 ja_JP 本地环境中 二十七 分析为 27,容许但不要求前导零tm_mday
ed 的同义词tm_mday
OeOd 的同义词tm_mday
星期之日
a分析星期的日名,完整或缩写版,例如 Fritm_wday
Aa 的同义词tm_wday
w分析星期之日为十进制数,其中星期日为 0 (范围 [0-6]tm_wday
Ow用替代数值系统分析星期之日为十进制数,其中星期日为 0,例如 ja_JP 本地环境中 二 分析为 2tm_wday
时、分、秒
H分析为十进制数,以 24 小时时钟(范围 [00,23]),容许但不要求前导零tm_hour
OH用替代数值系统分析来自 24 小时时钟的,例如 ja_JP 本地环境中 十八 分析为 18tm_hour
I分析为十进制数,以 12 小时时钟(范围 [01,12]),容许但不要求前导零tm_hour
OI用替代数值系统分析,例如 ja_JP 本地环境中 六 分析为 6tm_hour
M分析为十进制数(范围 [00,59]),容许但不要求前导零tm_min
OM用替代数值系统分析,例如 ja_JP 本地环境中 二十五 分析为 25tm_min
S分析为十进制数(范围 [00,60]),容许但不要求前导零tm_sec
OS用替代数值系统分析,例如 ja_JP 本地环境中 二十四 分析为 24tm_sec
其他
c分析本地环境的标准日期和时间字符串格式,例如 Sun Oct 17 04:41:13 2010 (依赖本地环境)所有
Ec分析本地环境的替代时期和时间字符串格式,例如期待在 ja_JP 本地环境中以 平成23年 取代 2011年所有
x分析本地环境的标准日期表示所有
Ex分析本地环境的替代日期表示,例如期待在 ja_JP 本地环境中以 平成23年 取代 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 的函数显式设置它。


返回值

一个满足以下条件但未指定类型的对象:

  • 如果 in 是具有 std::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 中所指定,未指明此函数是否将未由 fmt 中出现的转换指定符所直接设置的 *tmb 中的字段清零:可移植程序在调用 std::get_time 前应该初始化 *tmb 的每个字段。

示例

注意:选择 clang 或 12.1 及以上版本的 gcc 以观察输出。12.1 版本以前的 libstdc++ 未正确实现 %b 指定符:漏洞 #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 << "解析失败\n";
    else
        std::cout << std::put_time(&t, "%c") << '\n';
}

可能的输出:

Sun Feb 18 23:12:34 2011

参阅

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