package main import ( "archive/zip" "bytes" "fmt" "os" ) func main() { // 创建一个缓冲区用来保存压缩文件内容 buf := new(bytes.Buffer) // 创建一个压缩文档 w := zip.NewWriter(buf) // 将文件加入压缩文档 var files = []struct { Name, Body string }{ {"Golang.txt", "http://task.lmcjl.com/golang/"}, } for _, file := range files { f, err := w.Create(file.Name) if err != nil { fmt.Println(err) } _, err = f.Write([]byte(file.Body)) if err != nil { fmt.Println(err) } } // 关闭压缩文档 err := w.Close() if err != nil { fmt.Println(err) } // 将压缩文档内容写入文件 f, err := os.OpenFile("file.zip", os.O_CREATE|os.O_WRONLY, 0666) if err != nil { fmt.Println(err) } buf.WriteTo(f) }运行上面的文件会在当前目录下生成 file.zip 文件,如下图所示:
图:生成的压缩文件及文件的内容
package main import ( "archive/zip" "fmt" "io" "os" ) func main() { // 打开一个zip格式文件 r, err := zip.OpenReader("file.zip") if err != nil { fmt.Printf(err.Error()) } defer r.Close() // 迭代压缩文件中的文件,打印出文件中的内容 for _, f := range r.File { fmt.Printf("文件名: %s\n", f.Name) rc, err := f.Open() if err != nil { fmt.Printf(err.Error()) } _, err = io.CopyN(os.Stdout, rc, int64(f.UncompressedSize64)) if err != nil { fmt.Printf(err.Error()) } rc.Close() } }运行结果如下:
go run main.go
文件名: Golang.txt
http://task.lmcjl.com/golang/
本文链接:http://task.lmcjl.com/news/13085.html