Я довольно новичок в использовании Django, и я пытаюсь создать сайт, на котором пользователь может загрузить несколько файлов excel, эти файлы затем сохраняются в папке с носителями Webproject/project/СМИ.Django скачать файл
def upload(request):
if request.POST:
form = FileForm(request.POST, request.FILES)
if form.is_valid():
form.save()
return render_to_response('project/upload_successful.html')
else:
form = FileForm()
args = {}
args.update(csrf(request))
args['form'] = form
return render_to_response('project/create.html', args)
Затем документ отображается в списке вместе с каким-либо другим документом, они загружены, которые вы можете нажать на, и он будет отображается основная информация о них и от имени excelfile они загружены. Отсюда я хочу, чтобы иметь возможность загрузить те же первенствует файл снова, используя ссылку:
<a href="/project/download"> Download Document </a>
Моих URLs являются
urlpatterns = [
url(r'^$', ListView.as_view(queryset=Post.objects.all().order_by("-date")[:25],
template_name="project/project.html")),
url(r'^(?P<pk>\d+)$', DetailView.as_view(model=Post, template_name="project/post.html")),
url(r'^upload/$', upload),
url(r'^download/(?P<path>.*)$', serve, {'document root': settings.MEDIA_ROOT}),
] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)
, но я получаю ошибку, служить() получила неожиданный аргумент ключевого слова ' document root '. может ли кто-нибудь объяснить, как это исправить?
ИЛИ
Объясните, каким образом я могу получить загруженные файлы будут выбраны и подается с помощью
def download(request):
file_name = #get the filename of desired excel file
path_to_file = #get the path of desired excel file
response = HttpResponse(mimetype='application/force-download')
response['Content-Disposition'] = 'attachment; filename=%s' % smart_str(file_name)
response['X-Sendfile'] = smart_str(path_to_file)
return response
можете ли вы включить код из представления 'serve'? – xthestreams