之前在做项目管理系统的时候需要实现将数据导出到excel表的功能,搜索之后发现了python的xlwt模块可以很好的实现这项功能。

  首先是导入xlwt模块:

import xlwt
from io import BytesIO

  将处理好的数据写入excel并且传给前端

# 获取当前时间
nowtime = datetime.datetime.now().strftime('%Y-%m-%d-%H-%M-%S')
# 创建一个workbook,设置编码格式为utf8
workbook = xlwt.Workbook(encoding='utf-8')
# 创建一个 worksheet
worksheet = workbook.add_sheet('Worksheet')
# 将处理好的数据写入excel,其中i为行,j为列
for i in range(len(msg_list)):
for j in range(len(msg_list[i])):
worksheet.write(i, j, msg_list[i][j])
# 创建操作二进制数据的对象
output = BytesIO()
# 将excel数据写入到内存中
workbook.save(output)
# 设置文件读取的偏移量,0表示从头读起
output.seek(0)
# 设置HTTP的报头为二进制流
self.set_header("Content-Type", "application/octet-stream")
# 设置文件名
self.set_header("Content-Disposition", "attachment; filename=export-%s.xls" % nowtime)
return self.write(output.getvalue())

  在前端我发现如果是通过a标签的href来请求对应的API接口,可以直接下载到excel文件,但是如果希望在发送请求时携带一些数据,则需要发送ajax请求,代码如下:

$("#export-from").submit(function(e){
e.preventDefault();
var data = {};
$(this).serializeArray().map(function(x){
data[x.name] = x.value;
});
if (data["start_time"] && data["end_time"]){
var url= ("api/export/results?start_time="+data["start_time"]+"&end_time="+data["end_time"]);
var xhr = new XMLHttpRequest();
xhr.open('GET', url, true);
// 返回blob类型,该类型用来存储二进制数据
xhr.responseType = "blob";
xhr.onload = function () {
// 请求完成,执行回调函数
if (this.status === 200) {
// 状态码为200
var blob = this.response;
var reader = new FileReader();
        // 转换为base64
reader.readAsDataURL(blob);
reader.onload = function (e) {
// 转换完成,创建一个a标签用于下载
var a = document.createElement('a');
a.download = 'results.xls';
a.href = e.target.result;
// 修复firefox中无法触发click
$("body").append(a);
a.click();
$(a).remove();
}
}
};
// 发送ajax请求
xhr.send()
}
});

python实现导出excel表(前端+后端)的更多相关文章

  1. 前端导出excel表

    前端导出excel表 方式一: 前端js实现 : https://www.cnblogs.com/zhangym118/p/6235801.html 方式二: java后端实现: https://bl ...

  2. thinkphp导入导出excel表单数据

    在PHP项目经常要导入导出Excel表单. 先去下载PHPExcel类库文件,放到相应位置. 我在thinkphp框架中的位置为ThinkPHP/Library/Org/Util/ 导入 在页面上传e ...

  3. 【ITOO 1】将List数据导出Excel表

    需求描述:在课表导入的时候,首先给用户提供模板(excel),然后将用户填写好的数据读取到list集合中.再进行判空处赋值处理,以及去重处理.这篇博客,主要介绍读取excel表和导出excel表的方法 ...

  4. ASP.NET导出excel表方法汇总

    asp.net里导出excel表方法汇总  1.由dataset生成 public void CreateExcel(DataSet ds,string typeid,string FileName) ...

  5. DateGridew导出Excel表+常见错误提示

    在敲机房收费系统的时候,显示数据的时候需要将DateGridew 中的数据导出进Excel表.DateGridew导出Excel表是比较常见的,当然导出Excel表有很多种方法,下面是个人认为比较容易 ...

  6. 传参导出Excel表乱码问题解决方法

    业务场景 先描述一下业务场景,要实现的功能是通过搜索框填写参数,然后点击按钮搜索数据,将搜索框的查询参数获取,附加在链接后面,调导Excel表接口,然后实现导出Excel功能.其实做导Excel表功能 ...

  7. C# asp.net中导出Excel表时总出现"只能在执行 Render() 的过程中调用 RegisterForEventValidation

    C# asp.net中导出Excel表时总出现"只能在执行 Render() 的过程中调用 RegisterForEventValidation 后台添加以下方法:/// <summa ...

  8. vue+element UI如何导出excel表

    导出excel表应按如下规则 首先要先安装如下依赖 npm install --save xlsx npm install --save file-saver 接下在在你的代码中去引用这两个 impo ...

  9. 微擎 人人商城 导出excel表分析

    在 数据处理上 ,有很多时候需要导出excel表  来当报表, 等 ,  php  人人商城导出报表过程简单分析 在导出时候发现 ca('statistics.order.export'); 出于好奇 ...

随机推荐

  1.  $(document).ready(function() { });

    l  $(document).ready(function() {   }); 初始化jsp

  2. matlab 打不开excel文件

    方法论 excel的后缀为.xls, matlab是无法识别的, 需要将其另存为.xlsx文件格式 打开excel, 点击save as, 选中保存的文件格式是.xlsx即可

  3. java获得文件扩展名

    java获得文件扩展名: public static void main(String[] args) throws Exception { String name = ""; S ...

  4. Golang自带的http包的路由规则问题

    1.调用下面的方法开启一个http监听服务http.HandleFunc("/hello/", helloHandler)err := http.ListenAndServe(&q ...

  5. Spring Cloud(2):搭建Eureka

    Eureka Server的搭建: 使用IDEA工具 File->New Project->Spring Initializr->next Next Next->Next创建即 ...

  6. html5的使用

    <!DOCTYPE html><html lang="en"><head> <meta charest="UTF-8" ...

  7. Markdown引用图片,且不使用网上链接的解决方法

    首先介绍下markdown使用图片的3种方法 使用本地图片,缺点是要用到本地的绝对路径,不适合对文档做迁移,否则会有图片链接失效的情况 ![thisisimage](C:\\Users\\Goose\ ...

  8. uvm_dpi——DPI在UVM中的实现(一)

    文件: src/dpi/uvm_dpi.svh 类:  无   SystemVerilog DPI,全称SystemVerilog直接编程接口 (英语:SystemVerilog Direct Pro ...

  9. C# DateTime的时区

    C#中可以通过DateTime的Kind属性指定DateTime的时区 DateTimeKind有3个枚举值: Unspecified:未指定为UTC时间或本地时间 Utc: UTC时间 Local: ...

  10. 用sql语句按周、按月、按季、按年统计

    --按mySql语法统计按周,月,季,年.income为合计的价格字段,createDate为交易时间. select sum(income)as revenue,week(createDate) a ...