用 Go 语言也能优雅输出表格!一招学会 tablewriter

在 Go 语言开发中,很多时候我们需要在命令行输出整齐、美观的表格数据,比如展示配置项、监控指标、执行结果等。这里要给大家介绍一个超实用的小工具------tablewriter

什么是 tablewriter?

tablewriter 是一个专门用于在终端中绘制文本表格的 Go 语言库。它可以帮助开发者以极简的方式输出格式化、对齐、美观的表格,不用自己辛苦拼接空格或边框,大大提升了 CLI 程序的观感和专业感。

只需要简单配置,就能快速输出支持自动对齐、自动换行、表头设置、边框美化等功能的表格。

如何在项目中使用 tablewriter?

  1. 安装依赖

首先,你需要在项目中引入 tablewriter

shell 复制代码
go get github.com/olekukonko/tablewriter
  1. 基本用法

来看看一个最简单的示例:

go 复制代码
package main

import (
	"os"
	"github.com/olekukonko/tablewriter"
)

func main() {
	data := [][]string{
		[]string{"Alfred", "24", "Engineer"},
		[]string{"Nancy", "29", "Designer"},
		[]string{"John", "31", "Manager"},
	}

	table := tablewriter.NewWriter(os.Stdout)
	table.SetHeader([]string{"Name", "Age", "Occupation"})

	for _, v := range data {
		table.Append(v)
	}
	table.Render() // 渲染表格输出
}

运行结果就像这样,非常整齐,另外如果需要在终端的左上角每次刷新覆盖之前的表格,可以在输出表格前通过 fmt.Print("\033[2J\033[H") 来清屏并将光标移到左上角:

shell 复制代码
+--------+-----+------------+
|  NAME  | AGE | OCCUPATION |
+--------+-----+------------+
| Alfred |  24 | Engineer   |
| Nancy  |  29 | Designer   |
| John   |  31 | Manager    |
+--------+-----+------------+
  1. 常用配置技巧
  • 设置表格风格

你可以自由配置是否显示边框、分隔线等:

go 复制代码
table.SetBorder(false)          // 不显示边框
table.SetRowLine(true)           // 每行之间显示线
table.SetAutoWrapText(false)     // 禁止自动换行
  • 对齐设置

可以单独设置列对齐方式,默认情况下数字类型右对齐、字符串或其他类型左对齐,可以通过 SetHeaderAlignmentSetAlignmentSetFooterAlignment方法指定表头、正文、表尾的对齐方式:

go 复制代码
table.SetAlignment(tablewriter.ALIGN_LEFT) // 表格内容居左对齐
  • 自定义表头颜色

可以使用 SetHeaderColor 设置彩色表头,让输出更醒目,另外通过SetColumnColorSetFooterColor能够分别对表内容、表尾指定颜色

go 复制代码
table.SetHeaderColor(
    tablewriter.Colors{tablewriter.Bold, tablewriter.FgHiRedColor},
    tablewriter.Colors{tablewriter.FgGreenColor},
    tablewriter.Colors{tablewriter.FgCyanColor},
)
  • 输出表格格式的文件

对于较小的文件可以在 os.Create 后直接对其进行写入操作:

go 复制代码
file, _ := os.Create("log.txt")
defer file.Close()
table := tablewriter.NewWriter(file)

如果文件比较大,可以将其拆分为一个个小块,再在缓冲区中进行写入操作:

go 复制代码
writer := bufio.NewWriter(file)
defer writer.Flush()
table := tablewriter.NewWriter(writer)
  1. 更多高级功能
  • 支持设置列宽、合并单元格
  • 可以添加 Footer(底部汇总行)
  • 支持 CSV 数据直接读取

总之,tablewriter 小而精悍,非常适合用在各种 CLI 工具、日志输出优化等场景,几乎是 Go 程序员必备的小工具之一!

相关推荐
free-9d3 小时前
NodeJs后端常用三方库汇总
后端·node.js
写不出来就跑路4 小时前
WebClient与HTTPInterface远程调用对比
java·开发语言·后端·spring·springboot
天上掉下来个程小白5 小时前
MybatisPlus-06.核心功能-自定义SQL
java·spring boot·后端·sql·微服务·mybatisplus
知了一笑5 小时前
独立开发第二周:构建、执行、规划
java·前端·后端
寻月隐君5 小时前
想用 Rust 开发游戏?这份超详细的入门教程请收好!
后端·rust·github
晴空月明6 小时前
分布式系统高可用性设计 - 缓存策略与数据同步机制
后端
Real_man6 小时前
新物种与新法则:AI重塑开发与产品未来
前端·后端·面试
小马爱打代码7 小时前
Spring Boot:将应用部署到Kubernetes的完整指南
spring boot·后端·kubernetes
卜锦元7 小时前
Go中使用wire进行统一依赖注入管理
开发语言·后端·golang
SoniaChen339 小时前
Rust基础-part3-函数
开发语言·后端·rust