Qt 重定位日至输出到文件
#include <QApplication>
#include <QFile>
#include <QMutex>
#include <QDateTime>
#include <QTextStream>
void myMessageOutput(QtMsgType type, const QMessageLogContext &context, const QString &msg)
{
// 加锁
static QMutex mutex;
mutex.lock();
QByteArray localMsg = msg.toLocal8Bit();
QString strMsg("");
switch(type)
{
case QtDebugMsg:
strMsg = QString("Debug : ");
break;
case QtInfoMsg:
strMsg = QString("Info : ");
break;
case QtWarningMsg:
strMsg = QString("Warning : ");
break;
case QtCriticalMsg:
strMsg = QString("Critical : ");
break;
case QtFatalMsg:
strMsg = QString("Fatal : ");
break;
}
// 设置输出信息格式
QString strDateTime = QDateTime::currentDateTime().toString("yyyy-MM-dd hh:mm:ss ddd");
QString strMessage = QString("%1 %2%3 ----- File: %4 ----- Line: %5 ----- Function: %6")
.arg(strDateTime).arg(strMsg).arg(localMsg.constData()).arg(context.file).arg(context.line).arg(context.function);
fprintf(stderr, "%s\n", strMessage.toStdString().c_str());
// 输出信息至文件中(读写、追加形式)
QFile file("log.txt");
file.open(QIODevice::ReadWrite | QIODevice::Append);
QTextStream stream(&file);
stream << strMessage << "\r\n";
file.flush();
file.close();
// 解锁
mutex.unlock();
}
int main(int argc, char **argv)
{
// 安装消息处理程序
qInstallMessageHandler(myMessageOutput);
QApplication app(argc, argv);
// 打印信息
qDebug("This is a debug message.");
qInfo("This is a qInfo message.");
qWarning("This is a warning message.");
qCritical("This is a critical message.");
// qFatal("This is a fatal message.");
return app.exec();
}
输出文件在运行目录下 log.txt 文件中