From f6202dfd77ce88fe59e66976f78b2e20878d7d9a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=97=A7=E4=BA=8B?= <545049148@qq.com> Date: Fri, 3 Mar 2023 21:48:25 +0800 Subject: [PATCH] =?UTF-8?q?=F0=9F=9A=A7=20=E6=96=B0=E5=A2=9E=E8=BF=9B?= =?UTF-8?q?=E5=BA=A6=E6=9D=A1=E6=98=BE=E7=A4=BA=E9=80=BB=E8=BE=91?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- backup4abap_go/main.go | 2 +- backup4abap_go/util/probar.go | 48 +++++++++++++++++++++++++++++++++++ backup4abap_go/util/zip.go | 19 ++++++++++++-- 3 files changed, 66 insertions(+), 3 deletions(-) create mode 100644 backup4abap_go/util/probar.go diff --git a/backup4abap_go/main.go b/backup4abap_go/main.go index 494f6de..0b469fb 100644 --- a/backup4abap_go/main.go +++ b/backup4abap_go/main.go @@ -132,7 +132,7 @@ func main() { UzipTime := time.Now() // 解压 - err = util.DeCompressed(filename) + err = util.DeCompressed(filename, set.ProcessBar) if err != nil { fmt.Println(err) return diff --git a/backup4abap_go/util/probar.go b/backup4abap_go/util/probar.go new file mode 100644 index 0000000..c15ff9f --- /dev/null +++ b/backup4abap_go/util/probar.go @@ -0,0 +1,48 @@ +package util + +import ( + "fmt" + "strings" +) + +type Bar struct { + percent int64 // 百分比 + curr int64 + total int64 + grap string + show string + IsInit bool +} + +func (bar *Bar) Init(total int64, grap string) { + bar.IsInit = true + bar.total = total + if grap == "" { + bar.grap = "#" + } + bar.show = strings.Repeat(bar.grap, 100) +} + +func (bar *Bar) percents() { + bar.percent = int64(float32(bar.curr) / float32(bar.total) * 100) +} + +func (bar *Bar) Add(desc string) { + if !bar.IsInit { + return + } + + bar.curr++ + + bar.percents() + + fmt.Printf("\r[%-50s]%3d%% %8d/%d %-10s", bar.show[:bar.percent/2], bar.percent, bar.curr, bar.total, desc) +} + +func (bar *Bar) End() { + if !bar.IsInit { + return + } + + fmt.Println() +} diff --git a/backup4abap_go/util/zip.go b/backup4abap_go/util/zip.go index fcfd404..010ada2 100644 --- a/backup4abap_go/util/zip.go +++ b/backup4abap_go/util/zip.go @@ -8,7 +8,9 @@ import ( "strings" ) -func DeCompressed(src string) error { +var probar Bar + +func DeCompressed(src string, procBar bool) error { ZipReader, err := zip.OpenReader(src) if err != nil { return err @@ -16,16 +18,29 @@ func DeCompressed(src string) error { defer ZipReader.Close() + fmt.Printf("解压数量:%6v\n", len(ZipReader.File)) + + if procBar { + probar.Init(int64(len(ZipReader.File)), "") + } + for _, f := range ZipReader.File { if err := deCompressed(f); err != nil { return err } } + + probar.End() + return nil } func deCompressed(f *zip.File) error { - fmt.Println(f.Name) + if probar.IsInit { + probar.Add(f.Name) + } else { + fmt.Println(f.Name) + } if f.FileInfo().IsDir() { err := os.MkdirAll(f.Name, 0755)