作者热门文章
- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我从 http 服务获取数据,我想即时解压它。这是我目前的方法:
resp, err := http.Get(url)
if err != nil {
logger.Fatalf("Can't fatch %s data. %v", url, err)
}
logger.Info("Fetched data from %s", url)
content_zipped, err := ioutil.ReadAll(resp.Body)
resp.Body.Close()
if err != nil {
logger.Fatal(err)
}
zip_reader, err := zip.NewReader(bytes.NewReader(content_zipped), int64(len(content_zipped)))
有什么方法可以解压 resp.Body 而无需一次读取所有内容(第 6 行)?我的意思是流字节。
最佳答案
Zip 文件需要随机访问才能读取,因此很难流式传输字节。特别是,请在此处查看 zip.Reader.init 的源代码:http://golang.org/src/pkg/archive/zip/reader.go?s=1265:1323#L59 .它做的第一件事是调用 readDirectoryEnd
,它从文件末尾附近开始读取。
能否使用不同的压缩方法(例如 gzip)?然后您可以使用 gzip.NewReader(resp.Body)
来流式传输数据。
关于zip - 如何解压 io.ReadCloser?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16946978/
我是一名优秀的程序员,十分优秀!