小编Car*_*ine的帖子

Django下载文件

我是使用Django的新手,我正在尝试开发一个用户可以上传大量excel文件的网站,然后将这些文件存储在媒体文件夹Webproject/project/media中.

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)
Run Code Online (Sandbox Code Playgroud)

然后,文档将与列表中的任何其他文档一起显示在列表中,您可以单击该文档,它将显示有关它们的基本信息以及它们已上载的文件的名称.从这里我希望能够使用以下链接再次下载相同的excel文件:

 <a  href="/project/download"> Download Document </a>
Run Code Online (Sandbox Code Playgroud)

我的网址是

 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)
Run Code Online (Sandbox Code Playgroud)

但是我得到了错误,serve()得到了一个意外的关键字参数'document root'.谁能解释如何解决这个问题?

要么

说明如何使用上传的文件进行选择和提供

def download(request):
    file_name = #get the filename of desired excel file
    path_to_file = #get the path of desired excel file …
Run Code Online (Sandbox Code Playgroud)

python django

31
推荐指数
4
解决办法
6万
查看次数

标签 统计

django ×1

python ×1