前往小程序,Get更优阅读体验!
立即前往
发布
社区首页 >专栏 >Go每日一库之116:pb(终端进度条)

Go每日一库之116:pb(终端进度条)

作者头像
luckpunk
发布2023-09-30 08:36:11
发布2023-09-30 08:36:11
59700
代码可运行
举报
运行总次数:0
代码可运行

什么是 pb?

pb是一个Go语言的终端进度条库。

什么时候需要pb?

终端显示的工具进行定时等待、IO传输等操作时,都可以用pb来显示当前进度。

pb入门

安装pb

代码语言:javascript
代码运行次数:0
复制
go get github.com/cheggaaa/pb/v3

快速上手

代码语言:javascript
代码运行次数:0
复制
package main
 
import (
 "time"
 
 "github.com/cheggaaa/pb/v3"
)
 
func main() {
 count := 100000
 
 // 创建进度条并开始
 bar := pb.StartNew(count)
 
 for i := 0; i < count; i++ {
  bar.Increment()
  time.Sleep(50 * time.Microsecond)
 }
 
 // 结束进度条
 bar.Finish()
}

我们可以看到如下的效果

代码语言:javascript
代码运行次数:0
复制
47921 / 100000 [--------------------->______________________] 47.92% 13945 p/s

自定义进度条的方法

代码语言:javascript
代码运行次数:0
复制
// 创建进度条
bar := pb.New(count)
 
// 设置刷新速度(时间间隔)(默认为200毫秒)
bar.SetRefreshRate(time.Second)
 
// 强制设置io.Writer,默认为os.Stderr
bar.SetWriter(os.Stdout)
 
// 进度条将数字格式化为字节(B、KiB、MiB等)
bar.Set(pb.Bytes, true)
 
// 进度条使用SI字节前缀名称(B,kB)代替IEC(B,KiB)
bar.Set(pb.SIBytesPrefix, true)
 
// 设置自定义的进度条模板
bar.SetTemplateString(myTemplate)
 
// 设置模板后检查错误
if err := bar.Err(); err != nil {
return
}
 
// 进度条开始
bar.Start()

IO操作的进度条

代码语言:javascript
代码运行次数:0
复制
package main
 
import (
 "crypto/rand"
 "io"
 "io/ioutil"
 
 "github.com/cheggaaa/pb/v3"
)
 
func main() {
 var limit int64 = 1024 * 1024 * 500
 
 // 我们将把500MiB从/dev/rand复制到/dev/null
 reader := io.LimitReader(rand.Reader, limit)
 writer := ioutil.Discard
 
 // 开始进度条
 bar := pb.Full.Start64(limit)
 
 // 创建代理读取器
 barReader := bar.NewProxyReader(reader)
 
 // 从代理读取器复制
 io.Copy(writer, barReader)
 
 // 结束进度条
 bar.Finish()
}

运行效果

代码语言:javascript
代码运行次数:0
复制
258.07 MiB / 500.00 MiB [---------------->_______________] 51.61% 180.84 MiB p/s ETA 1s

自定义进度条模板

基于内置文本/模板包的渲染。您可以使用现有pb的元素,也可以创建自己的元素。

element.go 文件中描述了所有可用元素。

我们可以将下面这个例子带入到上面IO操作的进度条的DEMO中,这里就不展示效果了。

代码语言:javascript
代码运行次数:0
复制
tmpl := `{{ red "With funcs:" }} {{ bar . "<" "-" (cycle . "↖" "↗" "↘" "↙" ) "." ">"}} {{speed . | rndcolor }} {{percent .}} {{string . "my_green_string" | green}} {{string . "my_blue_string" | blue}}`
 
// 开始基于我们的模板的进度条
bar := pb.ProgressBarTemplate(tmpl).Start64(limit)
 
// 设置字符串元素的值
bar.Set("my_green_string", "green").Set("my_blue_string", "blue")

总结

pb可以帮助我们丰富Golang编写的终端工具,希望大家可以借此开发出更多实用且有趣的东西。 [

](https://blog.csdn.net/RA681t58CJxsgCkJ31/article/details/121298592)

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 什么是 pb?
  • 什么时候需要pb?
  • pb入门
    • 安装pb
    • 快速上手
    • 自定义进度条的方法
    • IO操作的进度条
    • 运行效果
    • 自定义进度条模板
  • 总结
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档