QT日志类

文章介绍了如何在C++项目中创建一个名为Log的类,用于处理不同类型的Qt消息并将其记录到administrators-log.txt文件中,包括debug、warning、critical和fatal消息。使用方法是在相关类的构造函数中实例化Log对象,Qt调试信息将自动被记录。
摘要由CSDN通过智能技术生成

文章目录


Log.h

// log.h
#ifndef LOG_H
#define LOG_H
class Log
{
public:
    Log();
    ~Log();
private:
};

#endif // LOG_H

Log.cpp

// log.cpp
#include "log.h"
#include <QTextStream>
#include <QFile>
#include <QDir>
#include <QDateTime>
void customMessageHandler(QtMsgType type, const QMessageLogContext& context, const QString& msg);
Log::Log()
{
    // 清空日志文件
    QFile logFile("Log/administrators-log.txt");
    if (logFile.exists()) {
        logFile.remove();
    }
    qInstallMessageHandler(customMessageHandler);
}

Log::~Log()
{
}

void customMessageHandler(QtMsgType type, const QMessageLogContext& context, const QString& msg)
{
    // 获取当前日期时间
    QString currentDateTime = QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss");

    // 构建日志信息
    QString logMessage = QString("[%1] ").arg(currentDateTime);

    switch (type) {
    case QtDebugMsg:
        logMessage += QString("Debug: %1").arg(msg);
        break;
    case QtWarningMsg:
        logMessage += QString("Warning: %1").arg(msg);
        break;
    case QtCriticalMsg:
        logMessage += QString("Critical: %1").arg(msg);
        break;
    case QtFatalMsg:
        logMessage += QString("Fatal: %1").arg(msg);
        break;
    }
    QDir path;
    if (!path.exists("Log")) {
        path.mkdir("Log");
    }
    // 写入日志文件
    QFile logFile("Log/administrators-log.txt");
    if (logFile.open(QIODevice::WriteOnly | QIODevice::Append)) {
        QTextStream textStream(&logFile);
        textStream << logMessage << endl;
        logFile.close();
    }
}

使用时只需要在想要输出日志的类的构造函数里加一句Log log;,后续的qDebug的内容就可以都输入到日志文件中了

  • 10
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值