简介

今天学个简单点的😀,termtables处理表格形式数据的输出。适用于随时随地的输出一些状态或统计数据,便于观察和调试。是一个很小巧的工具库。我在学习dateparse库时偶尔见遇到了这个库。

快速使用

本文代码使用 Go Modules。

创建目录并初始化:

  1. $ mkdir termtables && cd termtables
  2. $ go mod init github.com/go-quiz/go-daily-lib/termtables

安装termtables库:

  1. $ go get -u github.com/scylladb/termtables

最原始的termtables库为github.com/apcera/termtables,然后原始仓库已经被删除了。目前使用的都是其他人 fork 的仓库。

使用:

  1. package main
  2. import (
  3. "fmt"
  4. "github.com/scylladb/termtables"
  5. )
  6. func main() {
  7. t := termtables.CreateTable()
  8. t.AddHeaders("User", "Age")
  9. t.AddRow("dj", 18)
  10. t.AddRow("go-quiz", 30)
  11. fmt.Println(t.Render())
  12. }

运行:

  1. $ go run main.go
  2. +--------+-----+
  3. | User | Age |
  4. +--------+-----+
  5. | dj | 18 |
  6. | go-quiz | 30 |
  7. +--------+-----+

使用很方便,首先调用termtables.CreateTable()创建一个表格对象,调用该对象的AddHeader()方法添加头部信息,然后调用AddRow()逐行添加数据。最后调用Render()返回渲染后的表格字符串。

模式

处理普通的文本表格,termtables还支持输出 HTML 和 Markdown 格式的表格。只需要调用表格对象的SetModeHTML()/SetModeMarkdown()方法设置一些模式即可 。

  1. func main() {
  2. t := termtables.CreateTable()
  3. t.AddHeaders("User", "Age")
  4. t.AddRow("dj", 18)
  5. t.AddRow("go-quiz", 30)
  6. fmt.Println("HTML:")
  7. t.SetModeHTML()
  8. fmt.Println(t.Render())
  9. fmt.Println("Markdown:")
  10. t.SetModeMarkdown()
  11. fmt.Println(t.Render())
  12. }

运行:

  1. $ go run main.go
  2. HTML:
  3. <table class="termtable">
  4. <thead>
  5. <tr><th>User</th><th>Age</th></tr>
  6. </thead>
  7. <tbody>
  8. <tr><td>dj</td><td>18</td></tr>
  9. <tr><td>go-quiz</td><td>30</td></tr>
  10. </tbody>
  11. </table>
  12. Markdown:
  13. | User | Age |
  14. | ------ | --- |
  15. | dj | 18 |
  16. | go-quiz | 30 |

输出的格式可以直接用在 Markdown/HTML 文件中。

总结

今天轻松一下,了解了一个小巧的工具库termtables。虽然自己实现一个类似的也不复杂,termtables库额外帮我们处理了编码、字宽等比较繁琐的细节。有需要在写示例程序中打印类似表格之类的数据不妨试一试termtables

大家如果发现好玩、好用的 Go 语言库,欢迎到 Go 每日一库 GitHub 上提交 issue😄

参考

  1. Go 每日一库 GitHub:https://github.com/go-quiz/go-daily-lib
  2. termtables GitHub:github.com/scylladb/termtables