70 QDateTime时间戳转换有误

Posted Chasing_Chasing

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了70 QDateTime时间戳转换有误相关的知识,希望对你有一定的参考价值。

1 前言

        在开发工具中需要用时间戳转换成格式化时间来显示,但引用QT中自带的时间类QDateTime转换时,发现转换时间有误问题,转换的结果时分秒是正确的,但月份确实错误的。因此在未深入研究qt实现情况下,需要得到正确的格式化时间,需要另寻它法。

        本blog对该现象仅进行记录和给出“治标不治本的”解决方法。

2 现象

        首先给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环境得到正确的格式化时间,得需要用其它代码替换。

3 解决方法(之一)

        本次的解决方案是,通过使用通用的时间函数,来避开使用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!

以上是关于70 QDateTime时间戳转换有误的主要内容,如果未能解决你的问题,请参考以下文章

70 QDateTime时间戳转换有误

将包含 PostgreSQL 时间戳的 QString 转换为 QDateTime

13位时间戳转年月日时分秒

JS 计算两个时间戳相差年月日时分秒

如何在线程中使用QDateTime?

php如何计算两个时间戳之间相差的日时分秒