c++11多种格式时间转化为字符串的方法实现
1.打印系统当前时间,或者将系统当前时间转化为字符串
#include <iostream> #include <sstream> #include <iomanip> #include <chrono> int main() { //打印到标准输出 auto t = std::chrono::system_clock::to_time_t(std::chrono::system_clock::now()); std::cout << std::put_time(std::localtime(&t), "%F %T") << std::endl; //转为字符串 std::stringstream ss; ss << std::put_time(std::localtime(&t), "%F %T"); std::string str = ss.str(); return 0; }
运行截图:
代码讲解:
(1)%F %T 是格式化字符串,其中%F 代表 年-月-日 的组合。%T 代表 时:分:秒的组合
%F %T 等价于 %Y-%m-%d %H:%M:%S。 更加细粒度的控制,可以自己对应组合(%Y,%m...分别对应年月日时分秒,怎么控制输出随便你)。比如现在我只需要打印 时-分 这样的格式,换成 %H - %M 即可
一般记住这几个常用的格式就够应付大多数场景了,更全面的格式请参考
(2)关于chrono::system_clock的详细讲解,前看前文
2.将time_t 类型,或者 long long 类型代表的秒数转换为字符串
有时候我们和其他的函数,甚至其他语言交互的时候,对方向你抛出一个time_t 类型的时间,或者long long类型的时间,现在需要我们转换为字符串。别慌,请看下面示例:
#include <iostream> #include <iomanip> #include <chrono> int main() { //从1970年1月1日00:00:00所经过的秒数 long long seconds = 1532581415; std::time_t t(seconds); std::cout << std::put_time(std::localtime(&t), "[%F %T]") << std::endl; return 0; }
运行截图:
代码讲解:
【注意】: long long seconds 一定要是秒数。(如果是毫秒那就除以1000 转为秒咯,其他类似转),不然转换为std::time_t 就失败了。其他和前一个示例一样。
总结:
以前总是看别的语言 DateTime::toString("yyyy.MM.dd hh:mm:ss.zzz ddd")啥的非常方便格式化时间,现在c++ 11也可以啦,只要自己稍微封装下就好了。
更多的格式化字符串及意义:
转换 说明符 |
解释 | 使用的域 |
---|---|---|
% | 写字面的 % 。完整转换指定必须是 %% 。 | |
n (C++11) |
写换行符 | |
t (C++11) |
写水平制表符 | |
年 | ||
Y | 以 4 位十进制数写年。 | tm_year |
EY (C++11) |
以替用方式写年。例如在 ja_JP 本地环境中,以“平成23年”取代“2011年”。 | tm_year |
y | 写年的末 2 位十进制数(范围[00,99])。 | tm_year |
Oy (C++11) |
以替用数字系统写年的末 2 位数字。例如在 ja_JP 本地环境中以“十一”取代“11”。 | tm_year |
Ey (C++11) |
将年写作从本地环境的替用时期 %EC 的偏移(本地环境依赖)。 | tm_year |
C (C++11) |
写年的首 2 位十进制数(范围 [00,99] )。 | tm_year |
EC (C++11) |
以本地环境的替用表示写年份基底(时期),例如 ja_JP 中的“平成”。 | tm_year |
G (C++11) |
写基于 ISO 8601 的年,即是包含指定星期的年份。
IS0 8601 中星期以星期一开始,而且一年的首星期必须满足下列要求:
|
tm_year, tm_wday, tm_yday |
g (C++11) |
写基于 ISO 8601 的年,即是包含指定星期年份,的后 2 位数(范围 [00,99] )。
IS0 8601 中星期以星期一开始,而且一年的首星期必须满足下列要求:
|
tm_year, tm_wday, tm_yday |
月 | ||
b | 写缩略月名,例如 Oct (本地环境依赖)。 | tm_mon |
h (C++11) |
与 b 同意。 | tm_mon |
B | 写完整月名,例如 October (本地环境依赖)。 | tm_mon |
m | 将月写作十进制数(范围 [01,12] )。 | tm_mon |
Om (C++11) |
以替用数字系统写月。例如 ja_JP 本地环境中“十二”取代“12”。 | tm_mon |
星期 | ||
U | 以十进制数写年的星期(星期日是星期的首日)(范围 [00,53] )。 | tm_year, tm_wday, tm_yday |
OU (C++11) |
以替用数值系统写如同用 %U 的年的星期。例如“五十二”在 ja_JP 本地环境中取代“52”。 | tm_year, tm_wday, tm_yday |
W | 以十进制数写年的星期(星期一是星期的首日)(范围 [00,53] )。 | tm_year, tm_wday, tm_yday |
OW (C++11) |
以替用数值系统写如同用 %W 的年的第星期。例如“五十二”在 ja_JP 本地环境中取代“52”。 | tm_year, tm_wday, tm_yday |
V (C++11) |
写 ISO 8601 的年的星期(范围[00,53])。
IS0 8601 中星期以星期一开始,而且一年的首星期必须满足下列要求:
|
tm_year, tm_wday, tm_yday |
OV (C++11) |
以替用数值系统写如同用 %V 的年的星期。例如“五十二”在 ja_JP 本地环境中取代“52”。 | tm_year, tm_wday, tm_yday |
年/月之日 | ||
j | 以十进制数写年的第几日(范围 [001,366] )。 | tm_yday |
d | 以十进制数写月的第几日(范围 [01,31] )。 | tm_mday |
Od (C++11) |
以替用数字系统写零基的月的第几日。例如 ja_JP 本地环境中“二十七”取代“ 27 ”。
单字符前加空格。 |
tm_mday |
e (C++11) |
以十进制数写月的第几日(范围[01,31])。
单数字前加空格。 |
tm_mday |
Oe (C++11) |
以替用数字系统写一基的月的第几日。例如 ja_JP 本地环境中“二十七”取代“27”。
单字符前加空格。 |
tm_mday |
星期之日 | ||
a | 写缩略的星期日期名,例如 Fri (本地环境依赖)。 | tm_wday |
A | 写完整的星期日期名,例如 Friday (本地环境依赖)。 | tm_wday |
w | 以十进制数写星期日期,其中星期日是 0 (范围 [0-6] )。 | tm_wday |
Ow (C++11) |
用替用数字系统写星期日期,其中星期日是 0 。例如 ja_JP 本地环境中“二”取代“2”。 | tm_wday |
u (C++11) |
十进制数写星期日期,其中星期一是 1 ( ISO 8601 格式)(范围 [1-7] )。 | tm_wday |
Ou (C++11) |
用替用数字系统写星期日期,其中星期一是 1 。例如 ja_JP 本地环境中“二”取代“2”。 | tm_wday |
时、分、秒 | ||
H | 以十进制数写时, 24 小时制(范围 [00-23] )。 | tm_hour |
OH (C++11) |
以替用数字系统写 24 小时制的时。例如 ja_JP 本地环境中“十八”取代“18”。 | tm_hour |
I | 以十进制数写时, 12 小时制(范围 [01,12] )。 | tm_hour |
OI (C++11) |
以替用数字系统写 12 小时制的时。例如 ja_JP 本地环境中“六”取代“6”。 | tm_hour |
M | 以十进制数写分(范围 [00,59] )。 | tm_min |
OM (C++11) |
以替用数字系统写分。例如 ja_JP 本地环境中“二十五”取代“25”。 | tm_min |
S | 以十进制数写秒(范围 [00,60] )。 | tm_sec |
OS (C++11) |
以替用数字系统写秒。例如 ja_JP 本地环境中“二十四”取代“24”。 | tm_sec |
其他 | ||
c | 写标准日期时间字符串。例如 Sun Oct 17 04:41:13 2010 (本地环境依赖)。 | 全部 |
Ec (C++11) |
写替用日期时间字符串。例如 ja_JP 本地环境中“平成23年”取代“2011年”。 | 全部 |
x | 写本地化的日期表示(本地环境依赖)。 | 全部 |
Ex (C++11) |
写替用日期表示。例如 ja_JP 本地环境中“平成23年”取代“2011年”。 | 全部 |
X | 写本地化的时间表示,例如 18:40:20 或 6:40:20 PM (本地环境依赖)。 | 全部 |
EX (C++11) |
写替用时间表示(本地环境依赖)。 | 全部 |
D (C++11) |
等价于"%m/%d/%y"。 | tm_mon, tm_mday, tm_year |
F (C++11) |
等价于"%Y-%m-%d"( ISO 8601 日期格式)。 | tm_mon, tm_mday, tm_year |
r (C++11) |
写本地化的 12 小时制时间(本地环境依赖)。 | tm_hour, tm_min, tm_sec |
R (C++11) |
等价于"%H:%M"。 | tm_hour, tm_min |
T (C++11) |
等价于"%H:%M:%S"( ISO 8601 时间格式)。 | tm_hour, tm_min, tm_sec |
p | 写本地化的 a.m. 或 p.m. (本地环境依赖)。 | tm_hour |
z (C++11) |
以 ISO 8601 格式(例如 -0430 )写距 UTC 的偏移,或者倘若时区信息不可用则不写字符。 | tm_isdst |
Z | 写依赖本地环境的时区名或缩写,或者若时区信息不可用则不写字符。 | tm_isdst |
到此这篇关于c++11多种格式时间转化为字符串的方法实现的文章就介绍到这了,更多相关c++11时间转化为字符串内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Qt图形图像开发之QT滚动区控件(滚动条)QScrollArea的详细方法用法图解与实例
这篇文章主要介绍了Qt图形图像开发,QT滚动区控件(滚动条)QScrollArea的详细方法用法图解与实例,需要的朋友可以参考下2020-03-03
最新评论