nodejs+express使用ejsexcel做复杂导出Excel
admin
2023-07-27 15:00:12
0
  1. 注意:使用时需要了解模板接受的数据格式,并不是直接搞上去就可以了,凡是不是要有个吻合度吗。
    • 从数据库中取出数据
      nodejs+express使用ejsexcel做复杂导出Excel
  2. 大致处理后的数据格式为:
    nodejs+express使用ejsexcel做复杂导出Excel
  3. 这些都准备好了你还得需要样东西,模板;
    nodejs+express使用ejsexcel做复杂导出Excel
    <%forRBegin rs,i in data[0]%>:开始循环;因为数据封装为
    [
    [{},{},{},{}.....]
    ];所以通过data[0],
    即可取出所有数据,数组中套用数组;
    <%forREnd%>:结束循环;
    <%=rs.issue_name%>:通过你封装的key来取值;
  4. 现在是代码部分
    1. 加入ejsexcel
      var ejsexcel = require('ejsexcel');
      var fs = require('fs');
      当然,使用之前需要你添加这个模块(npm install ejsexcel)
  5. ./ 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");
    }
    });
    注:在任何时候,代码出现问题不要捉急,看一下错误提示是否是哪个模块没加,或者是引号问题等等,总之
    新中越毛躁,解决问题所花费的时间越多

相关内容

热门资讯

浙江宣传:“走个面儿”咋就没面... “咱北京两千多万人口,您受累,您走个面儿,把这第一波的票房带起来,咱就有了。”某知名导演的新片首映礼...
辞职声明仅95秒遭质疑,韩国队... 【环球时报综合报道】美加墨世界杯小组赛出局后,韩国队主教练洪明甫当地时间28日在墨西哥的韩国队大本营...
美媒爆料:美军第五舰队总部遭伊... 据美国《华尔街日报》27日报道,其通过对卫星图像、社交媒体视频和五角大楼记录的分析发现,今年2月底至...
英国智库给菲律宾GDP增速“浇... 【环球时报特约记者 叶满】英国经济研究机构凯投宏观发布的最新一期《亚洲经济展望》报告(以下简称“报告...
欧洲持续高温,有华人用冰箱降温... 连日来,欧洲多国迎来罕见极端高温天气,法国、德国、意大利等地气温持续飙升,部分地区突破40摄氏度。受...
伊副外长强调船只须按“伊朗线路... 伊朗外交部副部长加里巴巴迪当地时间29日晚间在接受采访时强调,所有船只均须按照“伊朗线路”通过霍尔木...
委内瑞拉强震已致1719人死亡 当地时间29日,委内瑞拉全国代表大会主席罗德里格斯通报,地震已造成该国1719人死亡,5034人受伤...
铋晟新材料申请氯氧化铋基复合材... 国家知识产权局信息显示,江苏铋晟新材料有限公司申请一项名为“一种氯氧化铋基复合材料及其制备方法和用途...
韩国政府将投资千万亿韩元于AI... 韩国总统李在明29日在总统府青瓦台主持召开会议,公布总额超千万亿韩元的半导体、物理人工智能(AI)和...
以色列防长称以伊可能随时再起冲... △卡茨(资料图)据以色列方面29日消息,以国防部长卡茨当天表示,鉴于复杂的安全局势和在黎巴嫩的军事行...