1. 环境

  Django (2.1.10) + Python3.6 + xlwt (1.3.0)

  操作系统使用的为:Windows 7

2. 接口代码

def now_export(request):
data_list = CIP.objects.all() # 获取数据的查询集
if not data_list:
return HttpResponse(json.dumps({"state": "", "msg": "查无数据,导出失败"}), content_type="application/json") ws = Workbook(encoding='utf-8') # 设置Excel为UTF-8的编码格式
w = ws.add_sheet(u"正在清洗的CIP报表") # 设置sheet名称
w.write(0, 0, "id")
w.write(0, 1, u"清洗线路")
w.write(0, 2, u"操作者")
w.write(0, 3, u"清洗目标")
w.write(0, 4, u"清洗类型")
w.write(0, 5, u"CIP状态")
w.write(0, 6, u"开始时间")
# 把需要导出的数据写到文件中
excel_row = 1
for obj in data_list:
w.write(excel_row, 0, excel_row)
w.write(excel_row, 1, obj.CIPNo)
w.write(excel_row, 2, obj.oper)
w.write(excel_row, 3, obj.ccid)
w.write(excel_row, 4, obj.mode)
w.write(excel_row, 5, "CIP程序启动")
w.write(excel_row, 6, datetime.strftime(obj.start_time, '%Y-%m-%d %H:%M:%S'))
excel_row += 1
sio = BytesIO() # 写出到IO
ws.save(sio)
sio.seek(0) # 重新定位到开始
response = HttpResponse(sio.getvalue(), content_type='application/vnd.ms-excel') # 设置文件格式为Excel
   # attachment(意味着消息体应该被下载到本地;大多数浏览器会呈现一个“保存为”的对话框,将filename的值预填为下载后的文件名)
   response['Content-Disposition'] = 'attachment; filename=test.xls'
   response.write(sio.getvalue())
   return response

提示:若出现 TypeError: string argument expected, got 'bytes'  错误。问题出现在使用StringIO的write方法上,用BytesIO替代StringIO即可解决问题,笔者这里已经替换过了

3. 前端请求

注意:但需要注意的是,如果想要用这种方式下载文件,不能使用AJAX的方式,而是应该新建一个<a>标签,模拟点击下载。原因为处于安全性考虑,JavaScript无法与磁盘进行交互,因此AJAX得到的内容将被保留在内存中,而不是磁盘上。

3.1 请求方式为GET时:

  此时直接在A标签的href属性中指定路由即可

<a class="btn btn-success radius r" style="line-height:1.6em;margin-top:3px" title="导出报表" href="/CIP/now_export/">导出报表</a>
3.2 请求方式为POST时:

  这种请求 需写一个form表单,把请求所需数据写在表单中,在A标签中指定表单的提交方法即可。(对于a标签实现post请求感兴趣的可以自行百度其他方法)

<a class="btn btn-success radius r" style="line-height:1.6em;margin-top:3px" title="导出报表" onclick="document.getElementById('form').submit();">
导出报表</a>
<form action="/CIP/draft_export/" method="post" id="form" enctype="multipart/form-data">
<div class="row cl">
<div class="formControls col-xs-8 col-sm-9">
<label class="form-label col-xs-4 col-sm-2">开始日期:</label>
<input type="text" style="width: 200px" onfocus="WdatePicker({ dateFmt:'yyyy-MM-dd',maxDate:'#F{$dp.$D(\'startdate\')||\'%y-%M-%d\'}'})"
id="startdate" class="input-text Wdate" name="startdate">
</div>
<div class="formControls col-xs-8 col-sm-9" style="width: 400px">
<label class="form-label col-xs-4 col-sm-2">结束日期:</label>
<input type="text" style="width: 200px" onfocus="WdatePicker({ dateFmt:'yyyy-MM-dd HH:mm:ss',minDate:'#F{$dp.$D(\'enddate\')}' })"
id="enddate" class="input-text Wdate" name="enddate">
</div>
</div>
<br>
<div class="row cl">
<div class="formControls col-xs-8 col-sm-9">
<label class="form-label col-xs-4 col-sm-2">线路:</label>
<span class="select-box">
<select class="select" id="line" name="line">
<option>all</option>
</select>
</span>
</div>
<div class="formControls col-xs-8 col-sm-9">
<label class="form-label col-xs-4 col-sm-2">目标:</label>
<span class="select-box">
<select class="select" id="goal" name="goal">
<option>all</option>
</select>
</span>
</div>
<a name="" id="" class="btn btn-success" onclick="search_date(1)"><i class="Hui-iconfont" ></i> 搜索</a>
</div>
</form>

  

Django导出数据为Excel,调用浏览器下载的更多相关文章

  1. java web 读取数据库数据写入Excel返回浏览器下载

    @RequestMapping(value = "/download", method = RequestMethod.GET) public void downstudents( ...

  2. asp.net 通过 Handler 导出数据至excel (让用户下载)

    效果图: 代码: Export2Excel.ashx <%@ WebHandler Language="C#" CodeBehind="Export2Excel.a ...

  3. django导出数据到excel

    import xlwt,StringIodef dumpData(request): #获取数据 activitys = Activity.objects.all().order_by('id') i ...

  4. Java操作Jxl实现导出数据生成Excel表格数据文件

    实现:前台用的框架是Easyui+Bootstrap结合使用,需要引入相应的Js.Css文件.页面:Jsp.拦截请求:Servlet.逻辑处理:ClassBean.数据库:SQLserver. 注意: ...

  5. 1.ASP.NET MVC使用EPPlus,导出数据到Excel中

    好久没写博客了,今天特地来更新一下,今天我们要学习的是如何导出数据到Excel文件中,这里我使用的是免费开源的Epplus组件. 源代码下载:https://github.com/caofangshe ...

  6. phpexcel如何读取excel的数据和如何导出数据到excel

    phpexcel如何读取excel的数据和如何导出数据到excel 一.总结 一句话总结:去官网看参考手册和api,或者找中文的博客或者参考手册 1.phpexcel插件如何下载? 其实这些插件不仅可 ...

  7. ASP导出数据到excel遇到的一些问题

    一直用动易平台的ASP做新闻发布网站,直到现在才接触导出数据到Excel的问题,目的在于公司要统计各部门的投稿量,要做这么个东西,实现起来是挺简单的,但是第一次做,还是费了一些功夫的,特此记录一下 主 ...

  8. 手把手教你springboot中导出数据到excel中

    手把手教你springboot中导出数据到excel中 问题来源: 前一段时间公司的项目有个导出数据的需求,要求能够实现全部导出也可以多选批量导出(虽然不是我负责的,我自己研究了研究),我们的项目是x ...

  9. Dynamics CRM导出数据到Excel

    原创地址:http://www.cnblogs.com/jfzhu/p/4276212.html 转载请注明出处 Pivot Table是微软BI的一个重要工具,所以这里讲一下Dynamics CRM ...

随机推荐

  1. Java学习日记基础篇(九) —— 集合框架,泛型,异常

    集合框架 有事我们会需要一个能够动态的调整大小的数组,比如说要添加新员工但是数组已经满了,并且数组的大小是在定义的时候定死的,所以我们就需要一个能够动态调整大小的数组或者用链表解决,而java中提供了 ...

  2. PHP 之Html标签转义与反转义

    1.htmlentities()函数转义html 2.html_entity_decode()函数反转义html 我这里是用来反转义富文本编辑器的内容

  3. 详解DLX及其应用

    什么是DLX? 让我们看看百度百科上的解释:在 计算机科学 中, Dancing Links ,舞蹈链, 也叫 DLX, 是由 Donald Knuth 提出的数据结构,目的是快速实现他的 X算法.X ...

  4. OpenFOAM中的热传导?【翻译】

    翻译自:CFD-online 帖子地址:http://www.cfd-online.com/Forums/openfoam/70758-conductive-heat-transfer-openfoa ...

  5. 使用python3安装frida-tools出错

    执行安装命令 pip3.6 install frida-tools 得到错误信息 error: <urlopen error [SSL: CERTIFICATE_VERIFY_FAILED] c ...

  6. 在IntelliJ IDEA中启动tomcat出现Can't load AMD 64-bit .dll on a IA 32-bit' platform问题详解

    第一查看jdk版本 第二查看IntelliJ IDEA中运行tomcat的配置的jdk 比较两个jdk版本是否一致.或者查看tomcat是64还是32位的

  7. 0.9.0.RELEASE版本的spring cloud alibaba nacos实例

    简而言之,nacos与eureka的不同之处有三:后台老板.部署方式.功能.nacos是阿里的,eureka是奈飞的:nacos有自己的安装包,需要独立部署,eureka仅作为一个服务组件,引入jar ...

  8. java-selenium 框架例子

    package mavenweb2; import org.openqa.selenium.By; import org.openqa.selenium.WebDriver; import org.o ...

  9. 【转】hr的嘴,骗人的鬼

    入职前,从上往下读,入职后,从下往上读. - 我们非常欢迎新鲜血液补充进我们的团队:- 如果条件太苛刻,我待不久的:- 我们公司绝对不可能这样:- 请问每个月的工作都能按时足额发放吗?- 这难道不是理 ...

  10. 【Leetcode_easy】690. Employee Importance

    problem 690. Employee Importance 题意:所有下属和自己的重要度之和,所有下属包括下属的下属即直接下属和间接下属. solution:DFS; /* // Employe ...