日志基础示例python和c++

文章目录

  • 0. 引言
  • 1. python
  • 2. c++

0. 引言

本文主要记录python版本和c++版本常用的日志基础示例。

1. python

python版本常用的是logging库,结合colorlog库,可根据不同日志级别打印不同颜色的日志,为了便于分析问题,还添加了日志保存到文件的设置,默认保存到代码运行目录的logs/时间戳目录下,代码示例如下:

import logging
import colorlog
import os
from datetime import datetimeclass ColorLogger:SUCCESS_LEVEL_NUM = 25def __init__(self, name='app_logger', log_dir='logs', level=logging.DEBUG):# 定义 SUCCESS 级别logging.addLevelName(self.SUCCESS_LEVEL_NUM, "SUCCESS")# 创建日志目录if not os.path.exists(log_dir):os.makedirs(log_dir)# 创建带时间戳的子目录timestamp = datetime.now().strftime("%Y_%m_%d_%H_%M_%S")log_folder = os.path.join(log_dir, timestamp)os.makedirs(log_folder)# 日志文件路径log_file = os.path.join(log_folder, 'app.log')# 自定义日志记录方法def success(self, message, *args, **kwargs):if self.isEnabledFor(ColorLogger.SUCCESS_LEVEL_NUM):self._log(ColorLogger.SUCCESS_LEVEL_NUM, message, args, **kwargs)# 将自定义方法绑定到 Logger 类logging.Logger.success = success# 创建 logger 对象self.logger = logging.getLogger(name)self.logger.setLevel(level)# 创建控制台 handlerconsole_handler = colorlog.StreamHandler()console_formatter = colorlog.ColoredFormatter("%(log_color)s%(asctime)s - %(levelname)s - %(message)s",log_colors={'DEBUG': 'blue','INFO': '','WARNING': 'yellow','ERROR': 'red','CRITICAL': 'bold_red','SUCCESS': 'green'})console_handler.setFormatter(console_formatter)self.logger.addHandler(console_handler)# 创建文件 handlerfile_handler = logging.FileHandler(log_file)file_handler.setLevel(level)file_formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(message)s')file_handler.setFormatter(file_formatter)self.logger.addHandler(file_handler)def debug(self, message):self.logger.debug(message)def info(self, message):self.logger.info(message)def warning(self, message):self.logger.warning(message)def error(self, message):self.logger.error(message)def critical(self, message):self.logger.critical(message)def success(self, message):self.logger.success(message)# 实例化示例
if __name__ == "__main__":logger = ColorLogger()test = "1234567890"# 记录各种级别的日志logger.info(f"这是测试信息 {test}")logger.debug("这是调试信息 (DEBUG)")logger.info("这是普通信息 (INFO)")logger.warning("这是警告信息 (WARNING)")logger.error("这是错误信息 (ERROR)")logger.critical("这是严重错误信息 (CRITICAL)")logger.success("这是成功信息 (SUCCESS)")

运行结果:

请添加图片描述

2. c++

c++也可以实现类似的效果,main.cpp 代码如下:

#include <iostream>
#include <fstream>
#include <iomanip>
#include <ctime>
#include <sstream>
#include <filesystem>class ColorLogger {
public:enum LogLevel { DEBUG, INFO, WARNING, ERROR, CRITICAL, SUCCESS };ColorLogger(const std::string& name = "app_logger", const std::string& logDir = "logs"): loggerName(name), logDirectory(logDir) {// 创建日志目录if (!std::filesystem::exists(logDirectory)) {std::filesystem::create_directory(logDirectory);}// 创建带时间戳的子目录std::string timestamp = getCurrentTimestamp();logFolder = logDirectory + "/" + timestamp;std::filesystem::create_directory(logFolder);// 日志文件路径logFile = logFolder + "/app.log";logStream.open(logFile, std::ios::app);}~ColorLogger() {if (logStream.is_open()) {logStream.close();}}void log(LogLevel level, const std::string& message) {std::string prefix = getLogLevelString(level);std::cout << prefix << message << std::endl;  // 输出到控制台if (logStream.is_open()) {logStream << prefix << message << std::endl;  // 写入到文件}}void debug(const std::string& message) {log(DEBUG, message);}void info(const std::string& message) {log(INFO, message);}void warning(const std::string& message) {log(WARNING, message);}void error(const std::string& message) {log(ERROR, message);}void critical(const std::string& message) {log(CRITICAL, message);}void success(const std::string& message) {log(SUCCESS, message);}private:std::string loggerName;std::string logDirectory;std::string logFolder;std::string logFile;std::ofstream logStream;std::string getCurrentTimestamp() {auto now = std::time(nullptr);std::tm tm = *std::localtime(&now);std::ostringstream oss;oss << std::put_time(&tm, "%Y%m%d_%H%M%S");return oss.str();}std::string getLogLevelString(LogLevel level) {switch (level) {case DEBUG:   return "\033[34m[DEBUG] \033[0m";   // 蓝色case INFO:    return "\033[0m[INFO] \033[0m";     // 默认颜色case WARNING: return "\033[33m[WARNING] \033[0m";  // 黄色case ERROR:   return "\033[31m[ERROR] \033[0m";    // 红色case CRITICAL:return "\033[41m[CRITICAL] \033[0m"; // 红色背景case SUCCESS: return "\033[32m[SUCCESS] \033[0m";  // 绿色default:      return "\033[0m[UNKNOWN] \033[0m";   // 默认颜色}}
};// 实例化示例
int main() {ColorLogger logger;// 记录各种级别的日志logger.debug("这是调试信息 (DEBUG)");logger.info("这是普通信息 (INFO)");logger.warning("这是警告信息 (WARNING)");logger.error("这是错误信息 (ERROR)");logger.critical("这是严重错误信息 (CRITICAL)");logger.success("这是成功信息 (SUCCESS)");return 0;
}

对应的CMakeLists.txt如下:

cmake_minimum_required(VERSION 3.10)# 设置项目名称和版本
project(ColorLoggerProject VERSION 1.0)# 指定 C++ 标准
set(CMAKE_CXX_STANDARD 17)
set(CMAKE_CXX_STANDARD_REQUIRED True)# 添加可执行文件
add_executable(ColorLogger main.cpp)
mkdir build
cd build
make -j8
# 执行
./ColorLogger

运行结果:
请添加图片描述

当然,c++也有现成的库,比如glog,spdlog等,常用的是glog,示例代码如下:

需要先安装glog (推荐源码编译):

git clone https://github.com/google/glog.git
cd glog
mkdir build
cd build
cmake ..
make

main.cpp代码示例:

#include <glog/logging.h>
#include <iostream>
#include <string>int main(int argc, char* argv[]) {// 初始化 Google Logginggoogle::InitGoogleLogging(argv[0]);FLAGS_log_dir = "logs";std::string test = "1234567890";LOG(INFO) << "这是测试信息 " << test; // 普通信息LOG(WARNING) << "这是警告信息";       // 警告信息LOG(ERROR) << "这是错误信息";         // 错误信息// LOG(FATAL) << "这是致命错误信息"; // 致命错误(程序会终止)google::ShutdownGoogleLogging();return 0;
}

对应的CMakeLists.txt :common_lib_path 替换成自己编译的glob路径

cmake_minimum_required(VERSION 3.10)project(GlogExample)# 指定 C++ 标准
set(CMAKE_CXX_STANDARD 11)
set(CMAKE_CXX_STANDARD_REQUIRED True)set(common_lib_path "/nvme/PLITOE/common_lib")include_directories(${common_lib_path}/include)link_directories(${common_lib_path}/lib)# 添加可执行文件
add_executable(glog_example main.cpp)# 链接 glog 库
target_link_libraries(glog_example glog)
mkdir build
cd build
make -j8
# 执行,可先在当前文件夹下 mkdir logs
./glog_example

执行后,可在logs中看到各种级别的日志文件。






须知少时凌云志,曾许人间第一流。



⭐️👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍👍🌔

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/888926.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Linux】openssl version mismatch. built against 30000010, you have 30200020

错误&#xff1a;openssl version mismatch. built against 30000010, you have 30200020 这个错误通常是因为系统中安装了不同版本的 OpenSSL 库&#xff0c;导致程序在编译时使用了一个版本的 OpenSSL&#xff0c;而运行时却加载了另一个版本的库。根据错误信息&#xff0c;您…

智能码二维码的应用如何与其他技术(如物联网)结合,以提高电动工具行业的效率?

智能码二维码与物联网等技术的结合&#xff0c;能够多方面提高电动工具行业的效率&#xff0c;以下是详细介绍&#xff1a; 生产管理环节 与物联网传感器结合实现生产数据实时采集&#xff1a;在电动工具生产线上&#xff0c;为生产设备安装物联网传感器&#xff0c;并将传感器…

【Linux】基础IO-----文件详解

目录 一、文件理解&#xff1a; 二、C语言的文件操作&#xff1a; 1、fopen&#xff1a; 什么是当前路径&#xff1a; 2、fclose&#xff1a; 3、fwrite&#xff1a; 4、默认打开的三个流&#xff1a; 三、系统文件&#xff1a; 1、open&#xff1a; 2、close&#xf…

实时数据开发|Flink异步IO--提升性能和吞吐量

在使用Flink处理流式数据的过程中&#xff0c;会经常和外部系统进行数据交互。通常情况下在 Flink 中可以创建外部数据库系统的Client连接&#xff0c;然后通过Client连接将数据元素写入外部存储系统中或者从外部存储系统中读取数据。考虑到连接外部系统的网络等因素&#xff0…

Charts 教程:创建交互式图表的基础

ECharts 是一个开源的、基于 JavaScript 的数据可视化库&#xff0c;它可以帮助你快速创建交互式的图表。无论是简单的柱状图、折线图&#xff0c;还是复杂的地图和关系图&#xff0c;ECharts 都能够轻松应对。本文将带你了解如何在你的网页中使用 ECharts 创建图表&#xff0c…

【JAVA】Java高级:Spring框架与Java EE—Spring框架概述(控制反转、依赖注入)

Java开发中&#xff0c;Spring框架是一个极为重要的工具&#xff0c;它为开发者提供了一个全面的编程和配置模型&#xff0c;能够简化企业级应用程序的开发。Spring框架通过控制反转&#xff08;IoC&#xff09;和依赖注入&#xff08;DI&#xff09;等核心概念&#xff0c;使得…

鸿蒙面试---1208

HarmonyOS 三大技术理念 分布式架构&#xff1a;HarmonyOS 的分布式架构使得设备之间能够无缝协同工作。例如&#xff0c;它允许用户在不同的智能设备&#xff08;如手机、平板、智能手表等&#xff09;之间共享数据和功能。比如&#xff0c;用户可以在手机上开始编辑文档&…

26备战秋招day17——机器学习基础

机器学习入门指南&#xff1a;常见算法详解与代码实现 机器学习&#xff08;Machine Learning, ML&#xff09;是人工智能&#xff08;AI&#xff09;的一个重要分支&#xff0c;旨在通过数据驱动的方法让计算机系统自动学习和改进。对于刚接触机器学习的朋友来说&#xff0c;…

第7章:响应式设计 --[CSS零基础入门]

什么是响应式设计 响应式设计&#xff08;Responsive Web Design, RWD&#xff09;是一种网页设计和开发的方法&#xff0c;它使网站能够根据用户的设备特性&#xff08;如屏幕尺寸、分辨率、方向等&#xff09;自动调整其布局和内容。响应式设计的目标是确保网站在不同类型的…

探索 ONLYOFFICE 8.2 版本:更高效、更安全的云端办公新体验

引言 在当今这个快节奏的时代&#xff0c;信息技术的发展已经深刻改变了我们的工作方式。从传统的纸质文件到电子文档&#xff0c;再到如今的云端协作&#xff0c;每一步技术进步都代表着效率的飞跃。尤其在后疫情时代&#xff0c;远程办公成为常态&#xff0c;如何保持团队之间…

Vue-打印自定义HTML表格

自定义打印方法 1. 准备HTML结构 首先&#xff0c;构造了一个基本的HTML页面框架&#xff0c;并设置了页面的字符编码为UTF-8&#xff0c;以确保中文和其他特殊字符能正确显示。页面的标题设置为传入的 title 参数值。 let printStr "<html><head><met…

docker批量创建cloudstack虚拟主机脚本

批量创建cloudstack脚本 #!/bin/bash # 配置变量 container_prefix"cloudworker-" base_ip"192.168.1." start_ip2 #开始ip start_container2 #上同 end_container4 #结束ip 包括 network_name"my_macvlan_network" image_name"dockedahi:…

http1.0、1.1、2.0、 3.0

http1.0、1.1、2.0、 3.0 http1.1 引入长连接&#xff0c;在1.0&#xff0c;每次请求都需要建立新的TCP连接&#xff0c;处理请求完毕后立即断开。就导致处理大量图片&#xff0c;链接等资源&#xff0c;需要大量的连接与断开&#xff0c;造成资源浪费和时间延迟。而长连接允许…

跟着问题学15——GRU网络结构详解及代码实战

1 RNN的缺陷——长期依赖的问题 &#xff08;The Problem of Long-Term Dependencies&#xff09; 前面一节我们学习了RNN神经网络&#xff0c;它可以用来处理序列型的数据&#xff0c;比如一段文字&#xff0c;视频等等。RNN网络的基本单元如下图所示&#xff0c;可以将前面的…

pytest中使用conftest做测试前置和参数化

pytest中比较高阶的应用是&#xff0c;使用conftest去做测试前置工作、测试收尾工作和参数化。conftest是pytest的一个组件&#xff0c;用于配置测试环境和参数。通过conftest, 可以创建一个可复用的测试配置文件&#xff0c;以便在多个测试模块之间共享配置信息。即&#xff0…

04 创建一个属于爬虫的主虚拟环境

文章目录 回顾conda常用指令创建一个爬虫虚拟主环境Win R 调出终端查看当前conda的虚拟环境创建 spider_base 的虚拟环境安装完成查看环境是否存在 为 pycharm 配置创建的爬虫主虚拟环境选一个盘符来存储之后学习所写的爬虫文件用 pycharm 打开创建的文件夹pycharm 配置解释器…

mvn test 失败,单独运行单元测试成功

标题mvn test 失败&#xff0c;单独运行单元测试成功 使用junit4进行单元测试时是通过的&#xff0c;但是在执行maven的test与package时测试不通过 报错信息&#xff1a; parse data from Nacos error,dataId:guoyu-new-asset-dev.yml,data: ....... 配置文件内容 ....... o…

基于gitlab API刷新MR的commit的指定status

场景介绍 自己部署的gitlab Jenkins,并已经设置好联动(如何设置可以在网上很容易搜到)每个MergeRequest都可以触发多个Jenkins pipeline&#xff0c;pipeline结束后会将状态更新到gitlab这个MR上希望可以跳过pipeline运行&#xff0c;直接将指定的MR的指定pipeline状态刷新为…

android 富文本及展示更多组件

模拟微博 #热贴 和 用户 的这种 富文本形式组件&#xff0c;不说了&#xff0c; 直接上代码 package com.tongtong.feat_watch.viewimport android.content.Context import android.graphics.Color import android.util.AttributeSet import android.view.LayoutInflater impo…

YourPHPCMS checkEmail SQL注入漏洞复现

0x01 产品简介 Yourphp企业网站管理系统是一款完全开源免费的PHP+MYSQL系统。核心采用了ThinkPHP框架,同时也作为开源软件发布。 集众多开源项目于一身的特点,使本系统从安全,效率,易用及可扩展性上更加突出。程序内置