go官方日志库带色彩格式化

go默认的 log 输出的日志样式比较难看,所以通过以下方式进行了美化和格式化,而且加入了 unicode 的ascii码,进行色彩渲染。

复制代码
package main

import (
	"fmt"
	"log"
	"os"
	"runtime"
	"strings"
	"time"
)

// 自定义日志格式
type CustomLogger struct {
	logger *log.Logger
}

var levelColors map[string]string = map[string]string{
	"DEBUG":    "[97;46m", // 蓝色
	"INFO":     "[97;42m", // 绿色
	"WARNING":  "[97;43m", // 黄色
	"ERROR":    "[97;41m", // 红色
	"CRITICAL": "[97;45m", // 红色加粗
	"SUCCESS":  "[97;42m", // 绿色加粗
}

// 初始化自定义日志
func NewCustomLogger() *CustomLogger {
	return &CustomLogger{
		logger: log.New(os.Stdout, "", 0), // 输出到标准输出,不带前缀
	}
}

// 自定义日志格式
func (l *CustomLogger) formatLog(level string, message string) string {
	// 获取当前时间
	now := time.Now().Format("2006-01-02 15:04:05.000")

	// 获取调用栈信息
	pc, file, line, ok := runtime.Caller(3) // 跳过三层调用栈
	caller := "unknown"
	if ok {
		funcName := runtime.FuncForPC(pc).Name()
		caller = fmt.Sprintf("%s:%d", file, line)
		if index := strings.LastIndex(funcName, "."); index != -1 {
			caller = fmt.Sprintf("%s.%s:%d", funcName[:index], funcName[index+1:], line)
		}
	}

	// 构建日志格式
	return fmt.Sprintf("[32m%s[0m |%s%s[0m| [35m%s[0m - [33m%s[0m",
		now, levelColors[level], level, caller, message)
}

// 日志输出函数
func (l *CustomLogger) Log(level string, message string) {
	logLine := l.formatLog(level, message)
	l.logger.Println(logLine)
}

// 不同级别的日志函数
func (l *CustomLogger) Info(message string) {
	l.Log("INFO", message)
}

func (l *CustomLogger) Infof(format string, v ...any) {
	message := fmt.Sprintf(format, v...)
	l.Log("INFO", message)
}

func (l *CustomLogger) Error(message string) {
	l.Log("ERROR", message)
}

func (l *CustomLogger) Errorf(format string, v ...any) {
	message := fmt.Sprintf(format, v...)
	l.Log("ERROR", message)
}

func (l *CustomLogger) Debug(message string) {
	l.Log("DEBUG", message)
}

func (l *CustomLogger) Debugf(format string, v ...any) {
	message := fmt.Sprintf(format, v...)
	l.Log("DEBUG", message)
}

下面是实际展示效果:

相关推荐
测试员周周几秒前
【Appium 系列】第10节-手势操作实战 — 滑动、拖拽、缩放与轻拂
linux·服务器·开发语言·人工智能·python·appium·pytest
雪度娃娃3 分钟前
转向现代C++——在创建对象时注意区分()和{}
开发语言·c++
铅笔小新z5 分钟前
【C语言】数组详解
c语言·开发语言
摇滚侠8 分钟前
Java 饿汉式 单例模式
java·开发语言·单例模式
lbb 小魔仙11 分钟前
工业数据困局的破局者:DolphinDB 如何让海量时序数据真正“跑“出价值
开发语言·人工智能·python·langchain
高旭的旭11 分钟前
Android Perfetto Profilers Skills 简明使用指南
android
枫叶丹413 分钟前
【HarmonyOS 6.0】Device Security Kit安全审计阻断功能深度解析
开发语言·安全·华为·harmonyos
读书札记202214 分钟前
C++ switch..case语句中变量跨域问题探讨及解决方法
开发语言·c++
一轮弯弯的明月14 分钟前
Spring AOP编程
java·开发语言·spring boot·笔记·spring aop·学习心得
ch.ju18 分钟前
Java程序设计(第3版)第四章——什么是对象
java·开发语言