信息发布→ 登录 注册 退出

golang 实用库gotable的具体使用

发布时间:2026-01-11

点击量:
目录
  • 一 背景
  • 二 库简介
  • 三 代码
    • 3.1 创建表格
    • 3.2 增加row
    • 3.3 增加column
    • 3.4 打印表格
    • 3.5 边框操作
    • 3.6 输出json
  • 四 测试
    • 4.1 创建表格
    • 4.2 输出json
  • 五 其他
    • 参考链接

      一 背景

      在使用cli打印结果的时候,对结果进行格式化输出,但限于内容较长的,不好自动排版,需要明确宽度等其他字段,可以使用gotable可以根据字段的长度自动调整每列的宽度,并且自动将字段居中显示。表格可以动态的新增列和数据。

      二 库简介

      gotable可以打印table到控制台,目前支持ASCII/Chinese characters 。
      可以非常轻松实现根据内容自调整局中显示,非常方便。

      三 代码

      3.1 创建表格

      func Create(columns ...string) (*table.Table, error)
      

      3.2 增加row

      增加单行

      func (tb *Table) AddRow(row map[string]string) error
      
      

      增加多行

      func (tb *Table) AddRows(rows []map[string]string) []map[string]string
      
      

      3.3 增加column

      func (tb *Table) AddColumn(column string) error
      

      3.4 打印表格

      func (tb *Table) PrintTable()
      

      3.5 边框操作

      关闭边框

      func (tb *Table) CloseBorder()

      开启边框

      func (tb *Table) OpenBorder()
      
      

      3.6 输出json

      func (tb *Table) Json(indent int) (string, error)
      

      四 测试

      4.1 创建表格

      package main
      
      import (
       "fmt"
       "github.com/liushuochen/gotable"
      )
      
      func main() {
      
       table, err := gotable.Create("country", "city")
       if err != nil {
        fmt.Println(err.Error())
        return
       }
      
       values := []map[string]string{{"country": "China", "city": "Beijing"},
        {"country": "Japan", "city": "Tokyo"},
        {"country": "North Korea", "city": "Pyongyang"}}
       for _, value := range values {
        err := table.AddRow(value)
        if err != nil {
         fmt.Println(err.Error())
         return
        }
       }
       r, _ := table.Json(4)
       fmt.Println(r)
       table.CloseBorder()
       table.PrintTable()
      }

      4.2 输出json

      package main
      
      import (
       "fmt"
       "github.com/liushuochen/gotable"
      )
      
      func main() {
       tb, err := gotable.Create("Name", "ID", "salary")
       if err != nil {
        fmt.Println("Create table failed: ", err.Error())
        return
       }
      
       rows := make([]map[string]string, 0)
       for i := 0; i < 3; i++ {
        row := make(map[string]string)
        row["Name"] = fmt.Sprintf("employee-%d", i)
        row["ID"] = fmt.Sprintf("00%d", i)
        row["salary"] = "60000"
        rows = append(rows, row)
       }
      
       jsonString, err := tb.Json(4)
       if err != nil {
        fmt.Println("ERROR: ", err.Error())
        return
       }
       fmt.Println(jsonString)
       // output: []
      
       tb.AddRows(rows)
      
       jsonString, err = tb.Json(4)
       if err != nil {
        fmt.Println("ERROR: ", err.Error())
        return
       }
       fmt.Println(jsonString)
       // output:
       // [
       //       {
       //              "ID": "000",
       //              "Name": "employee-0",
       //              "salary": "60000"
       //       },
       //       {
       //              "ID": "001",
       //              "Name": "employee-1",
       //              "salary": "60000"
       //
       //
       //              "ID": "002",
       //              "Name": "employee-2",
       //              "salary": "60000"
       //       }
       //]
      }

      五 其他

      利用golang 的 tabwriter也可以去实现打印表格,不过定义比较麻烦,更多高级功能可以自己定义,gotable拿来即用,可以配合表格输出和json输出到控制台的场景。

      参考链接

      https://github.com/liushuochen/gotable

      在线客服
      服务热线

      服务热线

      4008888355

      微信咨询
      二维码
      返回顶部
      ×二维码

      截屏,微信识别二维码

      打开微信

      微信号已复制,请打开微信添加咨询详情!