美文网首页
Qt开源作品22-运行时间记录类

Qt开源作品22-运行时间记录类

作者: feiyangqingyun | 来源:发表于2020-05-28 10:37 被阅读0次

一、前言

在早期开发的软件中,尤其是初学者入门者写的软件,软件运行久了,难免遇到意外崩溃的时候,可是大部分的运行设备可能在现场客户那,需要记住每一次从软件启动后到软件意外关闭前的运行时间,需要记录的信息包括:编号+开始时间+结束时间+已运行时间,每次完整的运行过程只产生一条记录,每次运行时间改变以后更新当前这条记录即可。这样就可以确切的了解到软件在现场的真实运行情况是否糟糕,如果没有这个记录(当然可以选择记录存储到数据库),程序又重启恢复了,也不知道到底每次运行了多久,从几点到几点。为了写的简单点,不干扰原有的数据库文件,我一般选择输出到文本文件。

主要功能:

  1. 可以启动和停止服务,在需要的时候启动。
  2. 可以指定日志文件存放目录。
  3. 可以指定时间日志输出间隔。
  4. 可以单独追加一条记录到日志文件。
  5. 日志为文本格式,清晰明了。

二、代码思路

void SaveRunTime::getDiffValue(const QDateTime &startTime, const QDateTime &endTime, int &day, int &hour, int &minute)
{
    qint64 sec = startTime.secsTo(endTime);
    day = hour = minute = 0;
    int seconds = 0;

    while (sec > 0) {
        seconds++;
        if (seconds == 60) {
            minute++;
            seconds = 0;
        }

        if (minute == 60) {
            hour++;
            minute = 0;
        }

        if (hour == 24) {
            day++;
            hour = 0;
        }

        sec--;
    }
}

void SaveRunTime::initLog()
{
    //判断当前年份的记事本文件是否存在,不存在则新建并且写入标题
    //存在则自动读取最后一行的id号  记事本文件格式内容
    //幢号    开始时间                结束时间                已运行时间
    //1      2016-01-01 12:33:33    2016-02-05 12:12:12     day: 0  hour: 0  minute: 0

    logFile = QString("%1/%2_runtime_%3.txt").arg(path).arg(name).arg(QDate::currentDate().year());
    QFile file(logFile);

    if (file.size() == 0) {
        if (file.open(QFile::WriteOnly | QFile::Text)) {
            QString strID = QString("%1\t").arg("编号");
            QString strStartTime = QString("%1\t\t").arg("开始时间");
            QString strEndTime = QString("%1\t\t").arg("结束时间");
            QString strRunTime = QString("%1").arg("已运行时间");
            QString line = strID + strStartTime + strEndTime + strRunTime;

            QTextStream stream(&file);
            stream << line << NEWLINE;
            file.close();

            lastID = 0;
        }
    } else {
        if (file.open(QFile::ReadOnly)) {
            QString lastLine;

            while (!file.atEnd()) {
                lastLine = file.readLine();
            }

            file.close();

            QStringList list = lastLine.split("\t");
            lastID = list.at(0).toInt();
        }
    }

    lastID++;
}

void SaveRunTime::appendLog()
{
    logFile = QString("%1/%2_runtime_%3.txt").arg(path).arg(name).arg(QDate::currentDate().year());
    QFile file(logFile);

    //写入当前首次运行时间
    if (file.open(QFile::WriteOnly | QFile::Append | QFile::Text)) {
        QString strID = QString("%1\t").arg(lastID);
        QString strStartTime = QString("%1\t").arg(startTime.toString("yyyy-MM-dd HH:mm:ss"));
        QString strEndTime = QString("%1\t").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd HH:mm:ss"));

        int day, hour, minute;
        getDiffValue(startTime, QDateTime::currentDateTime(), day, hour, minute);
        QString strRunTime = QString("%1 天 %2 时 %3 分").arg(day).arg(hour).arg(minute);
        QString line = strID + strStartTime + strEndTime + strRunTime;

        QTextStream stream(&file);
        stream << line << NEWLINE;
        file.close();
    }
}

void SaveRunTime::saveLog()
{
    //每次保存都是将之前的所有文本读取出来,然后替换最后一行即可
    logFile = QString("%1/%2_runtime_%3.txt").arg(path).arg(name).arg(QDate::currentDate().year());
    QFile file(logFile);

    //如果日志文件不存在,则初始化一个日志文件
    if (file.size() == 0) {
        initLog();
        appendLog();
        return;
    }

    if (file.open(QFile::ReadWrite)) {
        //一行行读取到链表
        QStringList content;
        while (!file.atEnd()) {
            content.append(file.readLine());
        }

        //重新清空文件
        file.resize(0);

        //如果行数小于2则返回
        if (content.count() < 2) {
            file.close();
            return;
        }

        QString lastLine = content.last();
        QStringList list = lastLine.split("\t");

        //计算已运行时间
        int day, hour, minute;
        getDiffValue(startTime, QDateTime::currentDateTime(), day, hour, minute);
        QString strRunTime = QString("%1 天 %2 时 %3 分").arg(day).arg(hour).arg(minute);

        //重新拼接最后一行
        list[2] = QDateTime::currentDateTime().toString("yyyy-MM-dd HH:mm:ss");
        list[3] = strRunTime;
        lastLine = list.join("\t");

        //重新替换最后一行并写入新的数据
        content[content.count() - 1] = lastLine;

        QTextStream stream(&file);
        stream << content.join("") << NEWLINE;
        file.close();
    }
}

三、效果图

在这里插入图片描述

四、开源主页

  • 以上作品完整源码下载都在开源主页,会持续不断更新作品数量和质量,欢迎各位关注。
  • 本开源项目已经成功升级到V2.0版本,分门别类,图文并茂,保你爽到爆。
  • Qt开源武林秘籍开发经验,看完学完,20K起薪,没有找我!
  1. 国内站点:https://gitee.com/feiyangqingyun/QWidgetDemo
  2. 国际站点:https://github.com/feiyangqingyun/QWidgetDemo
  3. 开源秘籍:https://gitee.com/feiyangqingyun/qtkaifajingyan
  4. 个人主页:https://qtchina.blog.csdn.net/
  5. 知乎主页:https://www.zhihu.com/people/feiyangqingyun/

相关文章

  • Qt开源作品22-运行时间记录类

    一、前言 在早期开发的软件中,尤其是初学者入门者写的软件,软件运行久了,难免遇到意外崩溃的时候,可是大部分的运行设...

  • Qt开源作品21-日志重定向输出类

    一、前言 用qt开发商业程序已经十年了,陆陆续续开发过至少几十个程序,除了一些算不算项目的小工具外,大部分的程序都...

  • Qt开源作品30-农历控件

    一、前言 农历控件在国产linux中必备的控件之一,毕竟要适应国人的习惯,你看win10系统的日历,现在点开来直接...

  • Github上的一些高分Qt开源项目

    Github上的一些高分Qt开源项目【多图】 本文转载自Github上的一些高分Qt开源项目【多图】[https:...

  • Qt开源作品29-NTP服务器时间同步

    一、前言 很多软件都有时间同步的功能,尤其是Qt在嵌入式设备上的,有时候还有很多是没有UI界面的程序,而硬件上有个...

  • python_图书管理系统

    用户类 书籍类 借阅记录类 书籍管理系统主程序 运行演示:

  • Qt仿腾讯视频简易播放器1.0.0.0 开源

    Qt仿腾讯视频简易播放器1.0.0.0 开源 @[toc] (一)、控件介绍 Qt仿腾讯视频简易播放器 依赖于Qt...

  • QT环境

    开源协议 LGPL:只要不修改和定制 Qt 库,仅使用 Qt 官方发布的动态链接库就可以不开源,这是商业友好的授权...

  • c++ ___ qt

    qt 下载地址 http://download.qt.io/archive/qt/ 一 互斥量 mutex 是个类...

  • Qt开源作品11-屏幕录制控件

    一、前言 在平时的写作过程中,经常需要将一些操作动作和效果图截图成gif格式,使得涵盖的信息更全面更生动,有时候可...

网友评论

      本文标题:Qt开源作品22-运行时间记录类

      本文链接:https://www.haomeiwen.com/subject/qdeoahtx.html