我在S3存储桶的单个文件夹中存储了很多图像。一共分为三类(假设是A,B和C),而图像只能属于这三类之一。我正在view-all.html页面上明智地渲染所有图像类别。我想做的是在view-all.html中每个类别的名称旁边添加一个单独的下载按钮。单击特定的下载按钮后,仅应将该类别下存在的图像下载为zip文件。目前,下载按钮不适用于任何类别。
我只编辑了view-all.html和views.py文件。我对此进行了大量搜索,但没有找到确切的解决方案。我不确定是否必须在其他文件中添加其他内容。请帮帮我。预先感谢。
view-all.html
{% extends "cms/base.html" %}
{% block title %}
View-all
{% endblock %}
{% block main %}
<style>
*{box-sizing: border-box;}
.wrapper{
overflow-x:scroll;
white-space: nowrap;
}
.container {
background: #ccc;
position: relative;
height: 50%;
display: inline-block;
}
img {
padding: 0;
display: block;
margin: 0 auto auto 0;
margin-left: auto;
margin-right: auto;
max-width: 100%;
}
.overlay {
position: absolute;
bottom: 0;
background: rgb(0, 0, 0);
background: rgba(0, 0, 0, 0.5);
color: #f1f1f1;
width: 93%;
transition: .5s ease;
opacity:0;
color: white;
font-size: 20px;
padding: 20px;
text-align: center;
}
.container:hover > .overlay {
opacity: 1;
}
@media only screen and (max-width : 767px)
{
height: auto;
max-height: none;
}
</style>
{% for category in categories %}
<br /><h3>{{ category.name }}  <button name='downloadbtn' class="btn btn-primary" onclick='bulkdownload()'><i class="fa fa-download"></i> Download</button> </h3>
<div class="wrapper">
<div id="slider4" class="text-center">
{% for image in images %}
{% ifequal image.category category %}
<div class="container">
<img src="S3-url">
<br />
</div>
{% endifequal %}
{% endfor %}
</div>
</div>
{% endfor %}
{% endblock %}
views.py
@login_required
def bulkdownload(request):
if(request.GET.get('downloadbtn')):
images = Images.objects.all().filter(category = request.category.name)
if images:
categories = request.category.name
zip_subdir = '{:%B %d, %Y}'.format(datetime.now()) # name of the zip file to be downlaoded
zip_filename = '%s.zip' % zip_subdir
# Open StringIO to grab in-memory ZIP contents
s = io.StringIO.StringIO()
# The zip compressor
zf = zipfile.ZipFile(s, 'w')
for fpath in images:
# Calculate path for file in zip
fdir, fname = os.path.split(fpath)
zip_path = os.path.join(zip_subdir, fname)
# Add file, at correct path
zf.write(fpath, zip_path)
# Must close zip for all contents to be written
zf.close()
# Grab ZIP file from in-memory, make response with correct MIME-type
resp = HttpResponse(s.getvalue(), content_type = 'application/x-zip-compressed')
# ..and correct content-disposition
resp['Content-Disposition'] = 'attachment; filename=%s' % zip_filename
return resp
答案 0 :(得分:0)
您可以创建表格并发布数据以下载图像,如下所示:
{% for category in categories %}
<form method='POST' action="{% url 'your_url_name_for_view' %}">
<br /><h3>{{ category.name }}  
<input type="hidden" value="{{ category.id }}" name="category_id">
<input name='downloadbtn' class="btn btn-primary" type="submit"><i class="fa fa-download"></i> Download</h3>
</form>
<div class="wrapper">
<div id="slider4" class="text-center">
{% for image in images %}
{% ifequal image.category category %}
<div class="container">
<img src="S3-url">
<br />
</div>
{% endifequal %}
{% endfor %}
</div>
</div>
{% endfor %}
现在,在您的视图中,您可以按以下方式检查类别:
if request.method == 'POST':
category_id = request.POST.get('category_id')
images = Images.objects.all().filter(category_id = category_id)
希望有帮助。