我正在 Go 中从 S3 下载一个 zip 文件,如下所示:buff := &aws.WriteAtBuffer{}downloader := s3manager.NewDownloader(session.New(config))_, err := downloader.Download(buff, &input)if err != nil { log.Println(err) return err}data := buff.Bytes()我将“数据”发送到用 Python3 编写的客户端,并且需要将此字节数组转换回 zip 文件并将其放在指定目录中。我试过这个:file_bytes = msg_obj["Params"]try: zf = zipfile.ZipFile(file_bytes, "r") for fileinfo in zf.infolist(): print(zf.read(fileinfo).decode('ascii'))except: print("Err:", sys.exc_info()[0])但我收到此错误:OSError: [Errno 36] 文件名太长”我只想“重建”zip 文件并将其保存到目录中。
2 回答
海绵宝宝撒
TA贡献1809条经验 获得超8个赞
我想出了如何做到这一点。在 go 中,您需要对其进行 base64 编码(作为字符串)。
buff := &aws.WriteAtBuffer{}
downloader := s3manager.NewDownloader(session.New(config))
_, err := downloader.Download(buff, &input)
if err != nil {
log.Println(err)
return err
}
data := b64.StdEncoding.EncodeToString(buff.Bytes())
然后在 python 中就这么简单(其中 'file_bytes' 是 base64 编码的字符串):
d = base64.b64decode(file_bytes)
f = open('home/update_file', 'wb')
f.write(d)
f.close()
bam,你有一个重新组装的 zip 文件。
一只甜甜圈
TA贡献1836条经验 获得超5个赞
阅读文档, ZipFile 类的第一个参数是文件名或文件对象,而不是 Zip 内容。
如果您想在不创建真实文件的情况下读取内存中的 ZipFile,则需要使用io.BytesIO包装 file_bytes 。
- 2 回答
- 0 关注
- 136 浏览
添加回答
举报
0/150
提交
取消