让CLI工具焕然一新!用golang与Color库打造多彩命令行体验
前段时间一直在使用 golang
打造CLI
小工具, 方便开发的时候使用, 如下图所示:
这些工具用起来确实非常好用,但是随着工具的增多,输出内容在使用过程中变得难以区分。为了解决这个问题,我开始使用第三方库Color
,对工具的输出进行了彩色化改造。对于习惯在命令行工具中输出日志或调试信息的开发者来说,彩色输出无疑是一种提升用户体验的方式,能够更直观地呈现信息。
fatih/color
fatih/color
是一个轻量级的Go语言库,允许开发者通过ANSI转义码在终端上输出带颜色的文字。 它不仅可以让你的文本有不同的前景色、背景色,还能让文字有不同的样式,比如粗体、下划线甚至斜体。最棒的是,这个库还支持Windows平台.
相比传统的单一颜色输出,彩色文本可以帮助用户快速定位问题,尤其在调试或查看日志时,能够大大提升效率。
安装
要使用fatih/color
,首先需要安装它,安装命令如下:
go get github.com/fatih/color
基本使用
接下来是一个简单的示例代码,展示如何使用fatih/color
库:
package main
import "github.com/fatih/color"
/**
* @Author: PFinal南丞
* @Author: lampxiezi@163.com * @Date: 2024/9/25 * @Desc: * @Project: 2024 */
func main() {
color.Cyan("PFinalClub")
color.Blue("PFinal %s", "Club")
color.Red("PFinalClub")
color.Magenta("PFinalClub")
c := color.New(color.FgCyan).Add(color.Underline)
_, _ = c.Println("PFinalClub")
d := color.New(color.FgCyan, color.Bold)
_, _ = d.Printf("PFinalClub %s\n", "too!.")
red := color.New(color.FgRed)
boldRed := red.Add(color.Bold)
_, _ = boldRed.Println("PFinalClub")
whiteBackground := red.Add(color.BgWhite)
_, _ = whiteBackground.Println("PFinalClub")
}
运行后效果如下:
这个库还提供了许多有趣的功能,可以用于各种场景。比如,下面的代码创建了带有多种样式的彩色输出:
// 实例化一个新的color对象,设置前景色为红色,背景色为绿色,文字斜体
colorPrint := color.New()
colorPrint.Add(color.Italic) // 设置文字为斜体
colorPrint.Add(color.FgRed) // 设置前景色为红色
colorPrint.Add(color.BgGreen) // 设置背景色为绿色
colorPrint.Println("Hello, World!") // 输出带样式的文字]
red := color.New(color.FgRed).PrintfFunc()
red("warning")
red("error: %s", err)
notice := color.New(color.Bold, color.FgGreen).PrintlnFunc()
notice("don't forget this...")
改造PF_tools
现在我们来看看如何将这个库应用于我们开发的小工具pf_tools
。
修改main.go
首先,我们在main.go
中加入Color
库的支持,并添加一个工具Logo:
package main
import (
"github.com/fatih/color"
"github.com/pfinal/pf_tools/cmd")
var Logo = `
欢迎使用pf_tools, 请按照下面的指示操作
`
func main() {
// 实例化一个新的color对象,设置前景色为红色,背景色为绿色,文字斜体
colorPrint := color.New(color.Bold)
colorPrint.Add(color.FgGreen)
_, _ = colorPrint.Println(Logo)
cmd.Execute()
}
这段代码为工具加了一个启动时显示的Logo
,并且使用绿色加粗的样式输出。
修改pf_cd
命令
接下来,对pf_cd
命令进行颜色输出的改造:
var pfCdCmd = &cobra.Command{
Use: "pf_cd",
Short: "清除目录中的.DS_Store 文件",
Long: `清除mac 目录中生成的.DS_Store 文件`,
Run: func(cmd *cobra.Command, args []string) {
colorPrint := color.New(color.Bold)
colorPrint.Add(color.FgGreen)
_, _ = colorPrint.Println("执行清除目录中的.DS_Store 文件 >>>>>>>")
var path string
if len(args) > 0 {
path = args[0]
} else {
path, _ = os.Getwd()
} colorPrint.Add(color.FgRed)
_, _ = colorPrint.Printf("清除目录的.DS_Store 文件: %s\n", path)
clearPath := pak.ClearPath{Path: path}
clearPath.ClearDotDSStore()
colorPrint.Add(color.FgGreen)
_, _ = colorPrint.Println("结束清除目录中的.DS_Store 文件 >>>>>>>")
},}
通过这段代码,我们不仅可以让命令行输出变得更加美观,还能通过不同颜色快速区分输出的不同阶段或内容。
效果如下 :
彩色的输出就是 不一样,好看整齐
总结
彩色化输出不仅可以提升CLI工具的视觉效果,还可以帮助用户更快速地识别关键信息。fatih/color
库提供了一个简单而强大的方式来实现这一点,无论是简单的颜色设置还是复杂的样式组合,都能轻易达成。通过将色彩融入你的CLI工具中,你不仅可以让用户的体验得到改善,同时也能让你的工具从众多同类产品中脱颖而出