当前位置 博文首页 > golang 实用库gotable的具体使用

    golang 实用库gotable的具体使用

    作者:kaliarch 时间:2021-08-03 18:04

    目录
    • 一 背景
    • 二 库简介
    • 三 代码
      • 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

        jsjbwy
        下一篇:没有了