NodeJs怎么实现下载Excel文件功能?


本文摘自PHP中文网,作者青灯夜游,侵删。

NodeJs怎么实现下载Excel文件功能?下面本篇文章就来给大家介绍一下。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

【视频教程推荐:node js教程 】

nodejs作为一门新的语言,报表功能也不是十分完善。

(1).js-xlsx : 目前 Github 上 star 数量最多的处理 Excel 的库,支持解析多种格式表格XLSX / XLSM / XLSB / XLS / CSV,解析采用纯js实现,写入需要依赖nodejs或者FileSaver .js实现生成写入Excel,可以生成子表Excel,功能强大,但上手难度稍大。不提供基础设置Excel表格api例单元格宽度,文档有些乱,不适合快速上手;

https://github.com/SheetJS/js-xlsx

(2).node-xlsx : 基于Node.js解析excel文件数据及生成excel文件,仅支持xlsx格式文件;

https://github.com/mgcrea/node-xlsx

(3).excel-parser : 基于Node.js解析excel文件数据,支持xls及xlsx格式文件,需要依赖python,太重不太实用;

https://github.com/leftshifters/excel-parser

(4).excel-export : 基于Node.js将数据生成导出excel文件,生成文件格式为xlsx,可以设置单元格宽度,API容易上手,无法生成worksheet字表,比较单一,基本功能可以基本满足;

https://github.com/functionscope/Node-Excel-Export

(5).node-xlrd : 基于node.js从excel文件中提取数据,仅支持xls格式文件,不支持xlsx,有点过时,常用的都是XLSX 格式。

nodejs刚出来那几年开发人员写了很多node依赖库,但是大部分现在处于不维护状态。

现在还在持续更新的只有node-xlsx excel-export推荐使用,js-xlsx作为一个大而全的基础库(虽然现在也不在更行了,此库最大的问题是api十分不友好,学习曲线高)有能力的项目组可以进一步封装,。

本篇为一个简单的下载的DEMO ,就简单使用excel-export,

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

var express = require('express');var router = express.Router();var server =  express();

 

server.use('/api', router);

var nodeExcel = require('excel-export');

  

const disableLayout ={layout: false};

 

 router.get('/test', function(req, res, next) {

     res.json({

         code:200

     })

 })

// disable interface layout.hbs  user config layout: falserouter.get('/exportExcel/:id', function(req, res, next) {    var conf ={};

    conf.stylesXmlFile = "styles.xml";

    conf.name = "mysheet";

    conf.cols = [{

        caption:'string',

        type:'string',

        beforeCellWrite:function(row, cellData){            return cellData.toUpperCase();

        },

        width:300

    },{

        caption:'date',

        type:'date',

        beforeCellWrite:function(){            var originDate = new Date(Date.UTC(1899,11,30));            return function(row, cellData, eOpt){

                console.log((cellData - originDate));                if (eOpt.rowNum%2){

                    eOpt.styleIndex = 1;

                }                else{

                    eOpt.styleIndex = 2;

                }                if (cellData === null){

                    eOpt.cellType = 'string';                    return 'N/A';

                } else

                    return (cellData - originDate) / (24 * 60 * 60 * 1000);

            }

        }()

    },{

        caption:'bool',

        type:'bool'

    },{

        caption:'number',

        type:'number'

    }];

    conf.rows = [

        ['pi', '2013-12-5', true, 3.14],

        ["e", new Date(2012, 4, 1), false, 2.7182],

        ["M&M<>'", new Date(Date.UTC(2013, 6, 9)), false, 1.61803],

        ["null date", null, true, 1.414]

    ];    var result = nodeExcel.execute(conf);

    res.setHeader('Content-Type', 'application/vnd.openxmlformats');

    res.setHeader("Content-Disposition", "attachment; filename=" + encodeURIComponent("导出列表")+".xlsx");

    res.end(result, 'binary');

});

  

router.get('/exportmultisheetExcel/:id', function(req, res, next) {    var confs = [];    var conf = {};

    conf.cols = [{

        caption: 'string',

        type: 'string'

    },

        {

            caption: 'date',

            type: 'date'

        },

        {

            caption: 'bool',

            type: 'bool'

        },

        {

            caption: 'number 2',

            type: 'number'

        }];

    conf.rows = [['hahai', (new Date(Date.UTC(2013, 4, 1))).oaDate(), true, 3.14], ["e", (new Date(2012, 4, 1)).oaDate(), false, 2.7182], ["M&M<>'", (new Date(Date.UTC(2013, 6, 9))).oaDate(), false, 1.2], ["null", null, null, null]];    for (var i = 0; i < 3; i++) {

        conf = JSON.parse(JSON.stringify(conf));   //clone

        conf.name = 'sheet'+i;

        confs.push(conf);

    }    var result = nodeExcel.execute(confs);

    res.setHeader('Content-Type', 'application/vnd.openxmlformats');

    res.setHeader("Content-Disposition", "attachment; filename=" + "Report.xlsx");

    res.end(result, 'binary');

});var server=server.listen(8080,function(){

    console.log('8080')

})

3.excel-export 提供了4种类型的数据格式,数字,时间,真假,默认字符串

cols可以为设置列类型的 caption为列名(会填充第一行的内容),type为列数据类型,beforeCellWrite可以在填充之前对数据进行逻辑处理,width可以定义宽带

rows为一个二位数组,直接按照行列方式填充excel的内容

name定义sheet的名字

值得注意的时候excel-export如果需要定义excel的默认格式,需要引用一个excel的格式头,这个头定义在styles.xml中,这个文件可以在node_modules/example/styles.xml中拷贝的项目对应目录

例子用的是根目录,所以我们需放在根目录,不然就会报找不到这个文件。

实际开发中,有时候excel的文件导出时要用中文,这时候要设置下header和格式化中文即可

res.setHeader('Content-Type', 'application/vnd.openxmlformats;charset=utf-8');
res.setHeader("Content-Disposition", "attachment; filename=" +encodeURIComponent("导出列表")+".xlsx");

更多编程相关知识,可访问:编程入门!!

以上就是NodeJs怎么实现下载Excel文件功能?的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

提示node应用性能的5个技巧

详解使用docker给nodejs程序打包的方法

浅谈nodejs利用node-xlsx模块读取excel数据的方法

详解nodejs中的事件循环机制

解决包管理工具 npm 和 yarn 下载安装超时的方法

nodejs适合做些什么?

深入浅析nodejs里的koa-static中间件

10个面向开发人员的顶级nodejs框架

深入了解调试nodejs程序的方法

nodejs怎么实现下载excel文件功能?

更多相关阅读请进入《nodejs》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...