提升效率之如何打印出漂亮的带颜色的日志(输出高亮)

2023-11-01


日志系统对于一个软件的维护是很重要的,对于直接在本地打印的信息,可能包含非常多,如何才能快速发现自己想要打印的东西呢?带上颜色的输出,绝对是很好的选择。
使用c/c++的输出可以照搬shell的,那么先来看下shell怎么花里胡哨的输出。

1. 花里胡哨的shell打印

shell花式输出
第二段就是我想要的结果,而第一段是错误的输出,颜色该结束还没结束,这个下面会说到原因。(不过我感觉都挺好看hhh,程序员的快乐就是这样的简单朴实)。
那么这是怎么搞得呢,废话不多说,上代码

#/bin/sh

#effect
echo -e "\033[1m Bold"        # bold effect
echo -e "\033[5m Blink"       # blink effect
echo -e "\033[0m Hello World" # back to normal

#color
echo -e "\033[31m Red"        # red
echo -e "\033[32m Green"      # green
echo -e "\033[33m Yellow"     # yellow
echo -e "\033[34m Blue"       # blue
echo -e "\033[35m Purple"     # purple
echo -e "\033[36m Cyan"       # cyan
echo -e "\033[0m Normal"      # back to normal

#background
echo -e "\033[41m Hello World Red\033[0m"
echo -e "\033[42m Hello World Green\033[0m"
echo -e "\033[43m Hello World Yellow\033[0m"
echo -e "\033[44m Hello World Blue\033[0m"
echo -e "\033[45m Hello World Purple\033[0m"
echo -e "\033[46m Hello World Cyan\033[0m"
echo -e "\033[0m Hello World Normal"

先来解释下参数

  • echo -e是激活特殊字符格式,这不必多说
  • “\033”引导非常规字符序列
  • “m”意味着设置属性然后结束非常规字符序列

所以决定什么颜色的就是这些数字了。下表即为数字的对照含义。

字颜色 背景颜色
红色 31 41
绿色 32 42
黄色 33 43
蓝色 34 44
紫色 35 45
蓝绿色 36 46
正常 0 0

还有一些是特殊效果

含义
0 OFF
1 高亮显示
4 下划线
5 闪烁(blink,虽然我没看出来怎么blink了)
7 反白显示
8 不可见

结合这些,我们可以做个实验
颜色实验

echo -e "\033[44;31;5m That is extremely cool \033[0m really?"

起作用的是 44;31;5,这个就是蓝色背景,红色字体,闪烁
实验证明了三点:

  1. 这三个参数的摆放位置是无关的。
  2. 最后要回归正常\033[0m,否则结果就是最后两次的输出尝试,这也是我上面截图所说的错误输出的地方。
  3. 不同背景颜色字体颜色效果的搭配会使输出看起来颜色不同,更好看hhh

从shell的这种输出也可以推广到c/c++或者其他语言。

2. c语言日志的彩色输出

echo是等价于printf的,其他等价转换一下就ok了,直接上代码。

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <stdarg.h>
#include <time.h>
#include <sys/timeb.h>



#define NONE        "\e[0m"
#define BLACK       "\e[0;30m"
#define L_BLACK     "\e[1;30m"
#define RED         "\e[0;31m"
#define L_RED       "\e[1;31m"
#define GREEN       "\e[0;32m"
#define L_GREEN     "\e[1;32m"
#define BROWN       "\e[0;33m"
#define YELLOW      "\e[1;33m"
#define BLUE        "\e[0;34m"
#define L_BLUE      "\e[1;34m"
#define PURPLE      "\e[0;35m"
#define L_PURPLE    "\e[1;35m"
#define CYAN        "\e[0;36m"
#define L_CYAN      "\e[1;36m"
#define GRAY        "\e[0;37m"
#define WHITE       "\e[1;37m"
#define BOLD        "\e[1m"
#define UNDERLINE   "\e[4m"
#define BLINK       "\e[5m"
#define REVERSE     "\e[7m"
#define HIDE        "\e[8m"
#define CLEAR       "\e[2J"
#define CLRLINE     "\r\e[K" //or "\e[1K\r"

#define log_info(format, ...)                                                                            \
    do                                                                                                      \
    {                                                                                                       \
        log_time(L_CYAN);                                                                                   \
        printf(L_CYAN "[WARN][%s][%s][%d]" format "\r\n", __FILE__, __FUNCTION__, __LINE__, ##__VA_ARGS__); \
        printf(NONE);                                                                                       \
    } while (0)

#define log_error(format, ...)                                                                            \
    do                                                                                                      \
    {                                                                                                       \
        log_time(L_RED);                                                                                   \
        printf(L_RED "[WARN][%s][%s][%d]" format "\r\n", __FILE__, __FUNCTION__, __LINE__, ##__VA_ARGS__); \
        printf(NONE);                                                                                       \
    } while (0)

#define log_warning(format, ...)                                                                            \
    do                                                                                                      \
    {                                                                                                       \
        log_time(YELLOW);                                                                                    \
        printf(YELLOW "[WARN][%s][%s][%d]" format "\r\n", __FILE__, __FUNCTION__, __LINE__, ##__VA_ARGS__); \
        printf(NONE);                                                                                       \
    } while (0)

#define log_bug(format, ...)                                                                                \
    do                                                                                                      \
    {                                                                                                       \
        log_time(L_BLUE);                                                                                   \
        printf(L_BLUE "[WARN][%s][%s][%d]" format "\r\n", __FILE__, __FUNCTION__, __LINE__, ##__VA_ARGS__); \
        printf(NONE);                                                                                       \
    } while (0)

#define log_time(color)                                                                                                                                      \
    do                                                                                                                                                      \
    {                                                                                                                                                       \
        struct tm *t;                                                                                                                                       \
        struct timeb stTimeb;                                                                                                                               \
        ftime(&stTimeb);                                                                                                                                    \
        t = localtime(&stTimeb.time);                                                                                                                       \
        printf(color "[%4d%02d%02d-%02d:%02d:%02d:%03d]", t->tm_year + 1900, t->tm_mon + 1, t->tm_mday, t->tm_hour, t->tm_min, t->tm_sec, stTimeb.millitm); \
        fflush(stdout);                                                                                                                                     \
        printf("\033[0m");                                                                                                                                  \
    } while (0)

int main()
{
    log_info("This is INFOMATION!");
    log_error("This is ERROR!");
    log_warning("This is WARNNING!");
    log_bug("This is BUG!");
    return 0;
}

效果如图:
花里胡哨的log
这样就完成了。
这个的代码有两点需要注意的

  1. 使用了可变参数 va_arg,不懂得可以看我这篇 c语言 神奇的可变参数
  2. 宏定义的do while(0)do{...}while(0)在C中是唯一的构造程序,让你定义的宏总是以相同的方式工作,这样不管怎么使用宏(尤其在没有用大括号包围调用宏的语句),宏后面的分号也是相同的效果。其实就是说,使用do{...}while(0)构造后的宏定义不会受到大括号、分号等的影响,总是会按你期望的方式调用运行。

这样打印出的相当于高亮的日志是容易被发现的,在学习工作中,应该会提高不少效率。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

提升效率之如何打印出漂亮的带颜色的日志(输出高亮) 的相关文章

随机推荐

  • python 出现socket.gaierror: [Errno 11004] getaddrinfo failed错误

    python 出现socket gaierror Errno 11004 getaddrinfo failed错误 报错详情 Traceback most recent call last File D JiCaiZhuanTi Case
  • 短信开发中的MT、MO是什么意思?

    MO Mobile originate MT Mobile Terminate MT 下行 即SP端下发给用户的信息 MO 上行 即用户上发给SP的信息 上行 mo提交短信到短信中心 下行 mt短信中心向特定的用户转发短信 你的短信是这样的
  • redis4.0集群搭建

    1 安装单机版Redis centos7可以yum直接安装 也可以通过源码包安装 以下仅展示源码编译安装 安装依赖 root localhost yum install gcc y 下载redis4 0 root localhost wge
  • 【习题四】【数据库原理】

    文章目录 一 单选题 二 填空题 三 简答题 Reference 一 单选题 1 表达了数据和处理过程的关系 A 数据字典 B 数据流图 C 逻辑设计 D 概念设计 正确答案 B 2 设计子模式属于数据库设计的 A 需求分析 B 概念设计
  • 为什么计算机采用二进制而不是八进制或者十六进制

    电子计算机能以极高速度进行信息处理和加工 包括数据处理和加工 而且有极大的信息存储能力 数据在计算机中以器件的物理状态表示 采用二进制数字系统 计算机处理所有的字符或符号也要用二进制编码来表示 用二进制的优点是容易表示 运算规则简单 节省设
  • 21亿春节红包撒出去,能缓解快手的流量焦虑吗?

    来源 连线Insight 编辑 李信 抖音作为央视春晚合作伙伴 着实火了一把 官方数据显示 春晚期间 抖音红包的总互动次数达到703亿 在抖音宣布成为2021年春晚独家红包互动合作伙伴时 最焦虑的莫过于快手 1月28日 快手官方微博宣布拿下
  • 类默认成员函数 - 析构函数

    析构函数与构造函数就是功能截然相反的两个函数了 析构函数就是将对象内部的资源进行清理 如malloc开辟的等 值得注意的是 很多人误以为析构函数是销毁对象 对象的销毁工作是由编译器完成的 我们现在说说析构函数的有那些特性 1 还是重析构函数
  • 咖说丨一文了解区块链在医疗领域的应用案例

    收集一众行业大咖观点 探索区块链商业及应用 百家争鸣 百花齐放 说理 解密 预测和八卦 了解行业内幕 看咖说就够了 投稿请联系 tougao conflux chain org 本文转自 白话区块链 作者 Wayne 换了一家医院就诊就要重
  • 阿里手淘猜你喜欢Swing算法介绍

    Swing算法原理比较简单 是阿里早期使用到的一种召回算法 在阿里多个业务被验证过非常有效的一种召回方式 它认为 user item user 的结构比 itemCF 的单边结构更稳定 Swing指的是秋千 例如用户 u uu 和用户 v
  • Shell常用的几个正则表达式:[:alnum:], [:alpha:], [:upper:], [:lower:], [:digit:] 认知

    一 通配符命令简介 匹配符合相关条件的符号 匹配文件名查找 通配符类型 匹配任意长度的任意字符 匹配任意单个字符 匹配指定范围内的任意单个字符 匹配指定范围之外的任意单个字符 space 空白字符 punct 标点符号 lower 小写字母
  • 由java转c++ 和qt的学习心得

    接触qt有一周左右了 写下这篇文章 用于反思自己前几日浑浑噩噩 也用于警醒自己 我是从java转到c 到qt开发的 原先以为编程语言是相通的 但是接触之后才发现 换一种新语言学 很难 接下来回顾两点 一 c 的学习思考 c 中 我认为最为重
  • 21.shell语言之if条件判断语句

    个人简介 作者简介 大家好 我是小鹏linux 运维领域新星创作者 个人主页 小鹏linux 支持我 点赞 收藏 留言 格言 你未必出类拔萃 但一定与众不同 系列专栏 阶段一 windows基础 原创16篇 阶段二 Linux基础知识 原创
  • Mac安装Redis后的配置

    Mac安装Redis后的配置 找到安装目录 配置文件修改 启动服务做测试连接 找到安装目录 1 双击 右键 访达 点击前往文件夹进行查找 如下图所示 2 然后再如下图所示中找到如下路径 usr local bin 3 找到redis con
  • hibernate mysql 超时_Hibernate连接数据库超时设置autoReconnect=true

    com mysql jdbc CommunicationsException The last packet successfully received from the server was58129 seconds ago The la
  • 小程序云开发——图片视频资源上传云端并返回云端路径

    在现在的应用中 包括小程序 图片视频等元素是产品必不可少的一部分 如果一个产品仅支持文字 将会很单调 有时候我们需要将图片视频上传到云端或者服务器 我这里将介绍在小程序中怎么上传图片和视频到云端 并返回云端路径 可以将这个云端路径存入数据库
  • 第三讲:IP地址和子网掩码

    一 标准分类的IP地址 每台计算机都要有IP地址 有了IP地址才能互相通信 计算机之间只能互相认识IP地址 IP地址可以理解为计算机的身份证号 一 二进制和十进制数转换 记住 10000000 2 128 10 1000000 2 64 1
  • PhpStorm+Xdebug+PHPStudy配置并调试

    首先 火狐浏览器搜索插件并安装 配置IDE key 打开phpinfo 将内容复制到Xdebug Support Tailored Installation Instructions 会推荐你适合版本的xdebug 当然你也可以选择phps
  • UE4 全局变量的应用(蓝图)

    4 20 1 创建全局变量 命名为MyGameInstance 2 创建一个变量 命名为MyB 3 在项目设置中 搜索GameInstence 并选中创建的全局变量 4 在蓝图里调用全局变量 5 成功打印
  • Tmux使用教程

    Tmux 是一款可以管理会话和分屏的终端复用器 在远程 SSH 断开后可以继续执行任务 重新连接后再继续会话 也能够将进程放到后台运行 需要时重新接管 为了防止 SSH 因网络断开造成的进程运行中断 推荐把所有需要长期运行的训练等任务都使用
  • 提升效率之如何打印出漂亮的带颜色的日志(输出高亮)

    花里胡哨的日志 1 花里胡哨的shell打印 2 c语言日志的彩色输出 日志系统对于一个软件的维护是很重要的 对于直接在本地打印的信息 可能包含非常多 如何才能快速发现自己想要打印的东西呢 带上颜色的输出 绝对是很好的选择 使用c c 的输