Django导出数据为Excel,调用浏览器下载
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,调用浏览器下载的更多相关文章
- java web 读取数据库数据写入Excel返回浏览器下载
@RequestMapping(value = "/download", method = RequestMethod.GET) public void downstudents( ...
- asp.net 通过 Handler 导出数据至excel (让用户下载)
效果图: 代码: Export2Excel.ashx <%@ WebHandler Language="C#" CodeBehind="Export2Excel.a ...
- django导出数据到excel
import xlwt,StringIodef dumpData(request): #获取数据 activitys = Activity.objects.all().order_by('id') i ...
- Java操作Jxl实现导出数据生成Excel表格数据文件
实现:前台用的框架是Easyui+Bootstrap结合使用,需要引入相应的Js.Css文件.页面:Jsp.拦截请求:Servlet.逻辑处理:ClassBean.数据库:SQLserver. 注意: ...
- 1.ASP.NET MVC使用EPPlus,导出数据到Excel中
好久没写博客了,今天特地来更新一下,今天我们要学习的是如何导出数据到Excel文件中,这里我使用的是免费开源的Epplus组件. 源代码下载:https://github.com/caofangshe ...
- phpexcel如何读取excel的数据和如何导出数据到excel
phpexcel如何读取excel的数据和如何导出数据到excel 一.总结 一句话总结:去官网看参考手册和api,或者找中文的博客或者参考手册 1.phpexcel插件如何下载? 其实这些插件不仅可 ...
- ASP导出数据到excel遇到的一些问题
一直用动易平台的ASP做新闻发布网站,直到现在才接触导出数据到Excel的问题,目的在于公司要统计各部门的投稿量,要做这么个东西,实现起来是挺简单的,但是第一次做,还是费了一些功夫的,特此记录一下 主 ...
- 手把手教你springboot中导出数据到excel中
手把手教你springboot中导出数据到excel中 问题来源: 前一段时间公司的项目有个导出数据的需求,要求能够实现全部导出也可以多选批量导出(虽然不是我负责的,我自己研究了研究),我们的项目是x ...
- Dynamics CRM导出数据到Excel
原创地址:http://www.cnblogs.com/jfzhu/p/4276212.html 转载请注明出处 Pivot Table是微软BI的一个重要工具,所以这里讲一下Dynamics CRM ...
随机推荐
- BZOJ1211树的计数
裸的prufer结论. 给个小链接prufer序列 ,里面有一个性质4就是本题答案,严谨证明可以上网找一找,如果从多组组合角度理解也可以. 剩下的就是特判,n==1时,du==0,1个,du!=0,废 ...
- javascript 的垃圾回收机制讲一下
定义:指一块被分配的内存既不能使用,又不能回收,直到浏览器进程结束. 像 C 这样的编程语言,具有低级内存管理原语,如 malloc()和 free().开发人员使用这些原语显式地对操作系统的内存进行 ...
- Python Log Viewer
https://pythonhosted.org/logview/
- API 设计 POSIX File API
小结: 1. https://mp.weixin.qq.com/s/qWrSyzJ54YEw8sLCxAEKlA API 设计最佳实践的思考 谷朴 阿里技术 昨天 阿里妹导读:API 是模块或者子 ...
- [Java复习] 设计模式 Design Pattern
设计模式的六大原则 1.开闭原则(Open Close Principle) 对扩展开放,对修改关闭. 2.里氏代换原则(Liskov Substitution Principle) 任何基类可以出现 ...
- 【407】C函数中的指针
注意:如果对于函数中指针参数的对应值进行修改,当调用该函数后,实参会被修改,所以如果不想要实参被修改,需要为函数的形参定义一个 str_copy 的量,通过 strcpy() 进行将字符串复制给 st ...
- Kafka Connect REST Interface
Since Kafka Connect is intended to be run as a service, it also supports a REST API for managing con ...
- Python的Asyncore异步Socket模块及实现端口转发的例子
Python的Asyncore异步Socket模块及实现端口转发的例子 Asyncore模块提供了以异步的方式写入套接字服务客户端和服务器的基础结构. 只有两种方式使一个程序在单处理器上实现" ...
- shuffle 打乱一维数组
<?php $arr = range(,); print_r($arr); echo '<br />'; shuffle($arr); print_r($arr); ?> Ar ...
- WPF窗体应用程序开发
1.Window:登录窗口.主窗体.消息框 2.UserControl:业务界面.消息框(如果使用UC来实现,则需要做特殊的处理,比如中断功能如何处理?)(显示一个UC,必须将其添加到容器中,所以&l ...