|
@@ -0,0 +1,84 @@
|
|
|
+package test
|
|
|
+
|
|
|
+import (
|
|
|
+ "archive/zip"
|
|
|
+ "fmt"
|
|
|
+ "io"
|
|
|
+ "os"
|
|
|
+ "path/filepath"
|
|
|
+ "strings"
|
|
|
+ "testing"
|
|
|
+)
|
|
|
+
|
|
|
+func TestZip(t *testing.T) {
|
|
|
+ src := "C:\\Users\\mlxengingin\\Desktop\\0813\\go从入门到通天(20)"
|
|
|
+ dest := "C:\\Users\\mlxengingin\\Desktop\\0813\\go从入门到通天(20).zip"
|
|
|
+ excludeDir := "C:\\Users\\mlxengingin\\Desktop\\0813\\go从入门到通天(20)\\搜索引擎"
|
|
|
+ err := ZipDir(src, dest, excludeDir)
|
|
|
+ if err != nil {
|
|
|
+ fmt.Println("Error:", err)
|
|
|
+ return
|
|
|
+ }
|
|
|
+ fmt.Println("Zip created successfully:", dest)
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+func ZipDir(src, dest, excludeDir string) error {
|
|
|
+ zipf, err := os.Create(dest)
|
|
|
+ if err != nil {
|
|
|
+ return err
|
|
|
+ }
|
|
|
+ defer zipf.Close()
|
|
|
+
|
|
|
+ archive := zip.NewWriter(zipf)
|
|
|
+ defer archive.Close()
|
|
|
+
|
|
|
+ filepath.Walk(src, func(path string, info os.FileInfo, err error) error {
|
|
|
+ if err != nil {
|
|
|
+ return err
|
|
|
+ }
|
|
|
+
|
|
|
+ header, err := zip.FileInfoHeader(info)
|
|
|
+ if err != nil {
|
|
|
+ return err
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ header.Name, err = filepath.Rel(src, path)
|
|
|
+ if err != nil {
|
|
|
+ return err
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ if strings.Contains(header.Name, excludeDir) {
|
|
|
+ if info.IsDir() {
|
|
|
+ return filepath.SkipDir
|
|
|
+ }
|
|
|
+ return nil
|
|
|
+ }
|
|
|
+
|
|
|
+ if info.IsDir() {
|
|
|
+ header.Name += "/"
|
|
|
+ } else {
|
|
|
+ header.Method = zip.Deflate
|
|
|
+ }
|
|
|
+
|
|
|
+ writer, err := archive.CreateHeader(header)
|
|
|
+ if err != nil {
|
|
|
+ return err
|
|
|
+ }
|
|
|
+
|
|
|
+ if !info.IsDir() {
|
|
|
+ file, err := os.Open(path)
|
|
|
+ if err != nil {
|
|
|
+ return err
|
|
|
+ }
|
|
|
+ defer file.Close()
|
|
|
+ _, err = io.Copy(writer, file)
|
|
|
+ return err
|
|
|
+ }
|
|
|
+ return nil
|
|
|
+ })
|
|
|
+
|
|
|
+ return nil
|
|
|
+}
|