目錄
- 一 背景
- 二 庫(kù)簡(jiǎn)介
- 三 代碼
- 3.1 創(chuàng)建表格
- 3.2 增加row
- 3.3 增加column
- 3.4 打印表格
- 3.5 邊框操作
- 3.6 輸出json
- 四 測(cè)試
- 4.1 創(chuàng)建表格
- 4.2 輸出json
- 五 其他
- 參考鏈接
一 背景
在使用cli打印結(jié)果的時(shí)候,對(duì)結(jié)果進(jìn)行格式化輸出,但限于內(nèi)容較長(zhǎng)的,不好自動(dòng)排版,需要明確寬度等其他字段,可以使用gotable可以根據(jù)字段的長(zhǎng)度自動(dòng)調(diào)整每列的寬度,并且自動(dòng)將字段居中顯示。表格可以動(dòng)態(tài)的新增列和數(shù)據(jù)。
二 庫(kù)簡(jiǎn)介
gotable可以打印table到控制臺(tái),目前支持ASCII/Chinese characters 。
可以非常輕松實(shí)現(xiàn)根據(jù)內(nèi)容自調(diào)整局中顯示,非常方便。
三 代碼
3.1 創(chuàng)建表格
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 邊框操作
關(guān)閉邊框
func (tb *Table) CloseBorder()
開(kāi)啟邊框
func (tb *Table) OpenBorder()
3.6 輸出json
func (tb *Table) Json(indent int) (string, error)
四 測(cè)試
4.1 創(chuàng)建表格
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也可以去實(shí)現(xiàn)打印表格,不過(guò)定義比較麻煩,更多高級(jí)功能可以自己定義,gotable拿來(lái)即用,可以配合表格輸出和json輸出到控制臺(tái)的場(chǎng)景。
參考鏈接
https://github.com/liushuochen/gotable
到此這篇關(guān)于golang 實(shí)用庫(kù)gotable的具體使用的文章就介紹到這了,更多相關(guān)golang gotable內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- Django中如何用xlwt生成表格的方法步驟
- django Layui界面點(diǎn)擊彈出對(duì)話框并請(qǐng)求邏輯生成分頁(yè)的動(dòng)態(tài)表格實(shí)例
- Python django搭建layui提交表單,表格,圖標(biāo)的實(shí)例
- django js 實(shí)現(xiàn)表格動(dòng)態(tài)標(biāo)序號(hào)的實(shí)例代碼
- django 在原有表格添加或刪除字段的實(shí)例
- MongoDB學(xué)習(xí)筆記(三) 在MVC模式下通過(guò)Jqgrid表格操作MongoDB數(shù)據(jù)