在开发工具中需要用时间戳转换成格式化时间来显示,但引用QT中自带的时间类QDateTime转换时,发现转换时间有误问题,转换的结果时分秒是正确的,但月份确实错误的。因此在未深入研究qt实现情况下,需要得到正确的格式化时间,需要另寻它法。
本blog对该现象仅进行记录和给出“治标不治本的”解决方法。
首先给QT环境下出常用的时间戳转换格式化时间的方法。
- QDateTime QDstarttime = QDateTime::fromTime_t(startTime); //时间戳非毫秒级
- QString strStartTime = QDstarttime.toString("yyyy-mm-dd hh:mm:ss");
- QDateTime QDstoptime = QDateTime::fromTime_t(stopTime); //时间戳非毫秒级
- QString strStopTime = QDstoptime.toString("yyyy-mm-dd hh:mm:ss");
基于上述代码的转换,对于两个时间戳分别是:1663223732 和 2114352000。转换结果如下图示,时、分、秒是正确的,但是月份是错误的。

对于时间戳的正确与否,特定通过在线转换工具来检验,如下图示,可知时间戳是没问题的。
1663223732 :

2114352000:

因此根据上述情况,很有理由怀疑qt时间转换函数有问题,但由于没有时间看qt源码,所以想要在qt环境得到正确的格式化时间,得需要用其它代码替换。
本次的解决方案是,通过使用通用的时间函数,来避开使用QT的函数,从而实现正确的转换。
-
- time_t stime_t = startTime;
- struct tm *pstm = localtime(&stime_t);
-
- char tsBuf[128] = {0};
- sprintf(tsBuf, "%04d-%02d-%02d %02d:%02d:%02d",
- pstm->tm_year+1900, pstm->tm_mon+1,
- pstm->tm_mday, (pstm->tm_hour)%24, //时区问题
- pstm->tm_min,pstm->tm_sec);
-
- QString strStartTime(tsBuf);
-
- time_t etime_t = stopTime;
- struct tm *petm = localtime(&etime_t);
-
- char teBuf[128] = {0};
- sprintf(teBuf, "%04d-%02d-%02d %02d:%02d:%02d",
- petm->tm_year+1900, pstm->tm_mon+1,
- petm->tm_mday, (petm->tm_hour)%24, //时区问题
- petm->tm_min,petm->tm_sec);
-
- QString strStopTime(teBuf);
用上述代码替换后,便可到正确的格式化时间。

over!