之前在做项目管理系统的时候需要实现将数据导出到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. webservice初识,SOAP1.1版本

    客户端与服务端模式,非web端发布 1.1      [Jax-ws第一个例子] 1.1.1     第一步:服务端开发 编写SEI(Service Endpoint Interface),SEI在w ...

  2. Apache禁止访问网站子目录的方法

    在PHP网站开发中,基于WEB服务器和PHP网站程序代码的安全考虑,我们需要对相关的目录或者文件访问权限进行控制,以防止意外情况的发生,那么我们如何来实现这种功能呢?我们可以通过Apache来实现禁止 ...

  3. MS Chart 折线图——去除时间中的时、分、秒,按天统计【转】

    MS Chart 折线图——去除时间中的时.分.秒,按天统计   private void Form2_Load(object sender, EventArgs e){            str ...

  4. IE6下float双边距问题

    当浮动元素的方向和设置margin的方向相同时,就会出现双边距问题,解决方法是: 删除浮动,改成display:inline-block _display:inline; _zoom:1;

  5. redhat配置dns服务器bind

    配置Oracle11g的RAC需要使用DNS服务器来解析SCAN IP,本文就是以此为例介绍bind服务器的使用.首先科普一下bind服务器,属于企业级产品了,还是开源的: Bind是Berkeley ...

  6. JQuery初识(二)

    一丶链式编程 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UT ...

  7. es6-Iterator与for...of

    Iterator(遍历器)的概念 JavaScript原有的表示“集合”的数据结构,主要是数组(Array)和对象(Object),ES6又添加了Map和Set.这样就有了四种数据集合,用户还可以组合 ...

  8. Java字节流与字符流的区别详解

    字节流与字符流 先来看一下流的概念: 在程序中所有的数据都是以流的方式进行传输或保存的,程序需要数据的时候要使用输入流读取数据,而当程序需要将一些数据保存起来的时候,就要使用输出流完成. 程序中的输入 ...

  9. Yii2 widgets [mztest/yii2-widget-file-upload]

    Enjoy it. A widget for uploading files to your server. Github , Packagist Screenshots

  10. POJ 1742 Coins(多重背包,优化)

    <挑战程序设计竞赛>上DP的一道习题. 很裸的多重背包.下面对比一下方法,倍增,优化定义,单调队列. 一开始我写的倍增,把C[i]分解成小于C[i]的2^x和一个余数r. dp[i][j] ...