最近做了一个小的业务模块,针对用户上传文件,然后后天进行数据处理的场景,场景比较简单,文件存储使用了七牛,简单的做了一个文件下载的例子
下面的跑了一个下载图片的例子,相关的参数可以自己配置
# -*- coding: utf-8 -*-
from __future__ import absolute_import
from __future__ import unicode_literals
import requests
from qiniu import Auth
access_key = 'xxxxxxxxxxxx'
secret_key = 'xxxxxxxxxxxx'
base_url = 'http://7xlhvy.com1.z0.glb.clouddn.com/FiMMeTmVVMfjadskZf7D1LArN5jbV6'
q = Auth(access_key, secret_key)
private_url = q.private_download_url(base_url, expires=3600)
r = requests.get(private_url)
# 注意下面的处理方式
if r.status_code == requests.codes.ok:
with open('m0.jpg', 'wb') as fd:
for chunk in r.iter_content(100):
fd.write(chunk)
截取 requests 官方文档一段话:
一般情况下,你应该以下面的模式将文本流保存到文件
但一般情况下,你应该以下面的模式将文本流保存到文件:
with open(filename, 'wb') as fd:
for chunk in r.iter_content(chunk_size):
fd.write(chunk)
使用 Response.iter_content
将会处理大量你直接使用 Response.raw
不得不处理的。 当流下载时,上面是优先推荐的获取内容方式。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。