django 完成excel文件下载,完整例子

从后端开始:

1、配置url

url('^download',downloadTest)

download就是请求的地址,downloadTest是视图方法需要后面实现

  2、编写视图方法downloadTest

from django.http import StreamingHttpResponse
def downloadTest(request):
    def file_iterator(file_name, chunk_size=512):#用于形成二进制数据
        with open(file_name,'rb') as f:
            while True:
                c = f.read(chunk_size)
                if c:
                    yield c
                else:
                    break
    the_file_name ="D:\test.xls"#要下载的文件路径
    response =StreamingHttpResponse(file_iterator(the_file_name))#这里创建返回
    response['Content-Type'] = 'application/vnd.ms-excel'#注意格式 
    response['Content-Disposition'] = 'attachment;filename="模板.xls"'#注意filename 这个是下载后的名字
    return response
#这里选用了StreamingHttpResponse返回,还有其他的方式,请查看下面的url
http://www.jianshu.com/p/2ce715671340
================================================================================================================================

前端:

1、在你的页面中增加

	<a href="/downloadTest" id="getDownLoad">点击下载</a>
    2、这样点击就会下载了
 如果是个下载按钮的话,可以这样:
    1、添加<a href="/downloadTest" id="getDownLoad"></a>
    2、给按钮绑定单击事件,事件内容就是触发 a 标签点击,也可以完成下载

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
### 回答1: 在Django中生成文件下载需要使用HttpResponse类。首先,在视图函数中打开要下载的文件,然后使用HttpResponse类将其作为附件返回给客户端。 示例代码: ``` from django.http import HttpResponse def download_file(request): file_path = '/path/to/your/file' with open(file_path, 'rb') as fh: response = HttpResponse(fh.read(), content_type="application/vnd.ms-excel") response['Content-Disposition'] = 'inline; filename=' + os.path.basename(file_path) return response ``` 在这个例子中,我们打开了一个文件,并使用HttpResponse类将其作为附件返回给客户端。Content-Disposition头指定了文件在客户端上的展示方式,可以是inline或者attachment。 请注意,文件的路径应该是绝对路径,如果是相对路径,可能会找不到文件。 ### 回答2: 在Django中,可以使用HttpResponse对象和FileWrapper对象来生成文件下载。 首先,我们需要创建一个视图函数,用于处理文件下载请求。在这个函数中,我们可以指定要下载的文件的路径和文件名。然后,我们可以使用Python的open函数打开文件,并使用FileWrapper对象来包装文件对象。 接下来,我们需要设置HttpResponse对象的一些header选项,以便浏览器能够正确处理文件下载。例如,我们可以设置Content-Type为'application/octet-stream',表示这是一个二进制文件。还可以设置Content-Disposition为'attachment; filename="filename"',表示这是一个要下载的文件,并指定下载后保存的文件名。 最后,我们将使用HttpResponse对象返回文件内容给浏览器。通过将FileWrapper对象传递给HttpResponse对象的iter_content方法,我们可以逐块迭代文件内容,将其发送给浏览器。需要注意的是,在迭代文件内容后,我们需要关闭文件对象。 下面是一个简单的示例代码: ```python from django.http import HttpResponse from wsgiref.util import FileWrapper import os def download_file(request): file_path = '/path/to/file' # 文件路径 file_name = 'example.txt' # 文件名 file = open(file_path, 'rb') file_wrapper = FileWrapper(file) response = HttpResponse(file_wrapper, content_type='application/octet-stream') response['Content-Disposition'] = f'attachment; filename="{file_name}"' file.close() # 关闭文件 return response ``` 以上代码片段中,我们打开了名为'example.txt'的文件,包装成FileWrapper对象,并将其传递给HttpResponse对象作为内容。最后,我们将文件下载的响应返回给浏览器。 请注意,这只是一个基本的示例,您可以根据实际需求对代码进行修改和扩展,以便实现更复杂的文件下载功能。 ### 回答3: 在Django中生成文件下载的过程如下: 1. 在views.py中,首先导入`FileResponse`类和`os`模块。`FileResponse`用于生成文件下载响应,`os`模块用于处理文件相关的操作。 2. 在函数视图中,获取需要下载的文件的路径和文件名称。可以通过`request.GET`获取url中的参数,或者从数据库中取得文件路径。 3. 使用`os.path`模块中的`isfile()`函数,判断文件是否存在。 4. 如果文件存在,则使用`open()`函数打开文件,并将其作为参数传入`FileResponse`类中创建一个文件响应对象。 5. 设置响应头,指定文件下载的名称。可以使用`response['Content-Disposition']`来指定下载的文件名。 6. 返回文件响应对象。 下面是一个示例代码: ```Python from django.http import FileResponse import os def download_file(request): file_path = 'path/to/your/file.txt' file_name = 'file.txt' # 判断文件是否存在 if os.path.isfile(file_path): # 打开文件并生成文件响应对象 file = open(file_path, 'rb') response = FileResponse(file) # 设置响应头,指定下载的文件名 response['Content-Disposition'] = 'attachment; filename=' + file_name return response else: # 文件不存在的处理逻辑 return HttpResponse('文件不存在!') ``` 要注意的是,这只是一个简单的示例代码,实际使用时可能需要根据具体需求进行修改和优化。
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值