nodejs+express使用ejsexcel做复杂导出Excel

  • 注意:使用时需要了解模板接受的数据格式,并不是直接搞上去就可以了,凡是不是要有个吻合度吗。
    • 从数据库中取出数据
  • 大致处理后的数据格式为:
  • 这些都准备好了你还得需要样东西,模板;

    <%forRBegin rs,i in data[0]%>:开始循环;因为数据封装为
    [
    [{},{},{},{}.....]
    ];所以通过data[0],
    即可取出所有数据,数组中套用数组;
    <%forREnd%>:结束循环;
    <%=rs.issue_name%>:通过你封装的key来取值;
  • 现在是代码部分
    1. 加入ejsexcel
      var ejsexcel = require(‘ejsexcel‘);
      var fs = require(‘fs‘);
      当然,使用之前需要你添加这个模块(npm install ejsexcel)
  • ./ GET export excel test. 导出excel议题/
    router.get(‘/exportExcel‘, function (req, res, next) {
    var filedir = ‘./public/uploadFile/temporaryFile/‘;
    fs.ensureDir(filedir, function (err) {
    });
    var meet_name = req.query.meet_name;
    try {
    //导出前判断要导出的文件是否存在,自己根据需求
    fs.exists(‘./public/uploadFile/temporaryFile/‘ + meet_name + ‘_xxx.xlsx‘, function (r) {
    if (r) {
    fs.unlink(‘./public/uploadFile/temporaryFile/‘ + meet_name + ‘_xxx.xlsx‘, function (err) {
    if (err) throw err;
    })
    }
    issueService.getIssueInfo(1, 10000, meet_name, function (result) {
    //查询数据
    if (result.rows.length < 1) {
    //没有数据返回0页面获取判断返回值做出相应的提示
    res.send("0");
    } else {
    fs.ensureDir(filedir, function (err) {});
    (async function () {
    var datas = [];
    var data = [];
    for (var i = 0; i < result.rows.length; i++) {
    /*
    处理数据为上述格式
    /
    data.push(result.rows[i]);
    }
    datas.push(data);
    //获得Excel模板的buffer对象
    const exlBuf = await readFileAsync(‘./public/uploadFile/template/issue.xlsx‘);
    //用数据源(对象)data渲染Excel模板
    const exlBuf2 = await ejsexcel.renderExcel(exlBuf, datas);
    await writeFileAsync(‘./public/uploadFile/temporaryFile/‘ + meet_name + ‘_议题报表.xlsx‘, exlBuf2);
    setTimeout(() => {
    console.info("删除议题");
    try {
    fs.access(‘./public/uploadFile/temporaryFile/‘ + meet_name + ‘_xxx.xlsx‘, fs.constants.F_OK,
    (err) => {
    if (!err) {
    fs.unlinkSync(‘./public/uploadFile/temporaryFile/‘ + meet_name + ‘_xxx.xlsx‘)
    }
    });
    } catch (e) {
    console.info("异常");
    console.error(e);
    }
    }, 5 60 1000);
    //返回生成的表格路径提供下载
    res.send(‘/uploadFile/temporaryFile/‘ + meet_name + ‘_xxx.xlsx‘);
    })();
    }
    });
    });
    } catch (error) {
    //返回异常
    res.send("err");
    }
    });
    注:在任何时候,代码出现问题不要捉急,看一下错误提示是否是哪个模块没加,或者是引号问题等等,总之
    新中越毛躁,解决问题所花费的时间越多
  • 原文地址:http://blog.51cto.com/13803916/2136470

    时间: 2024-11-09 05:46:47

    nodejs+express使用ejsexcel做复杂导出Excel的相关文章

    mvc4 用NPOI导出Excel

    第一次做数据导出Excel,刚看到这个的时候,首先想到的就是新建一个excel的文件,然后将它下载,后来询问别人,他们都推荐使用NPOI,发现这个很好用,就用博客记录一下 1.引用NPOI包 2.导出Excel /// <summary> /// 导出Excel /// </summary> /// <param name="collection"></param> /// <returns></returns>

    eggjs中使用exceljs直接导出excel文件

    最近要做一个导出excel表的功能,网上很多教程都是服务端生成excel文件,然后将excel文件返回给客户端,这样做的话服务端就会生成一个不需要的excel文件了,查了许久(本人太菜了莫见怪)找到了直接将excel文件生成到客户端的方法,这里记录一下,给那些和我一样找这个方法的童鞋.不多说了,写法如下: const Excel = require('exceljs'); let workBook = new Excel.Workbook(); // .... 这里是一系列添加数据操作,网上很多

    分针网——每日分享:nodejs导出excel实战

    本文转载:http://www.f-z.cn/id/268 我们都知道nodejs的内存由于v8内存分配机制的原因十分有限 64位系统也只能占1.4G左右, 因此当我们要生成或者读取大文件的时候内存的吃紧会给我们造成极大的困扰, 遇到这样的情况Node给了我们一个很好的解决方法 stream 简单的了解一下流 流是数据的集合 -- 就像数组或字符串一样.区别在于流中的数据可能不会立刻就全部可用,并且你无需一次性地把这些数据全部放入内存.这使得流在操作大量数据或是数据从外部来源逐段发送过来的时候变

    nodejs 导出excel

    nodejs 对查询数据生成excel并下载,采用方式先生成本excel文件,然后再下载:通过比较采用excel-export插件代码如下: excel.js代码: var extend = require("extend");var fs = require("fs");var excelExport = require('excel-export');var guid=require('guid');var path=require('path'); var e

    像在桌面手动创建表格一样,做一个共用のExcel导出

    [前言]昔日龌龊不足夸,今朝放荡思无涯. [思路]我们在桌面上创建Excel的时候: 1.首先创建一个Excel也就是 //声明工作薄 HSSFWorkbook wb = new HSSFWorkbook(); 2.接下来未页签sheet重命名,也就是 //sheet页签部分 HSSFSheet sheet = wb.createSheet("页签的名字"); 3.规划一下有多少列,再起一个标题,也就是 //合并标题 sheet.addMergedRegion(new Region(0

    使用POI做的一个生成Excel的工具类。包含了导出Excel和解析Excel方法

    PoiExcelUtils.java /** * */ package com.common.office; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.text.NumberFormat; import java.util.ArrayList; import java.util.Calendar; import java.util.List;

    React第六篇: 搭建React + Router + antd + nodejs + express框架搭建(nodejs做前后端server)

    前提: nodejs >= 10.0;  这里不推荐用官网的yarn安装antd的模块,因为后续会出错,错误如图: 也不推荐用npx方法来搭建react骨架,也会出错,让我们开始吧!!   前端React+Antd框架搭建 1.安装并启动create-react-app骨架应用 打开cmd按顺序执行以下指令: npm install -g create-react-app   (全局安装create-react-app, 默认会安装在C盘个人用户下) create-react-app my-ap

    Oracle导出excel

    oracle导出excel(非csv)的方法有两种,1.使用sqlplus  spool,2.使用包体 现将网上相关代码整理后贴出以备不时之需: 使用sqlplus: 使用sqlplus需要两个文件:sql脚本文件和格式设置文件. 去除冗余信息,main.sql --main.sql 注意,需要在sqlplus下运行 非plsql命令行下 set linesize 200 set term off verify off feedback off pagesize 999 set markup h

    使用Apache POI导出Excel小结--导出XLS格式文档

    使用Apache POI导出Excel小结 关于使用Apache POI导出Excel我大概会分三篇文章去写 使用Apache POI导出Excel小结--导出XLS格式文档 使用Apache POI导出Excel小结--导出XLSX格式文档 使用Apache POI导出Excel--大数量导出 导出XLS格式文档 做企业应用项目难免会有数据导出到Excel的需求,最近在使用其,并对导出Excel封装成工具类开放出来供大家参考.关于Apache POI Excel基本的概念与操作我在这里就不啰嗦