真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

NodeJs怎么實現(xiàn)下載Excel文件功能?

NodeJs怎么實現(xiàn)下載Excel文件功能?下面本篇文章就來給大家介紹一下。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有所幫助。

新邵網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)!從網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)等網(wǎng)站項目制作,到程序開發(fā),運營維護。創(chuàng)新互聯(lián)于2013年成立到現(xiàn)在10年的時間,我們擁有了豐富的建站經(jīng)驗和運維經(jīng)驗,來保證我們的工作的順利進行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)。

【視頻教程推薦:node js教程 】

nodejs作為一門新的語言,報表功能也不是十分完善。

(1).js-xlsx : 目前 Github 上 star 數(shù)量最多的處理 Excel 的庫,支持解析多種格式表格XLSX / XLSM / XLSB / XLS / CSV,解析采用純js實現(xiàn),寫入需要依賴nodejs或者FileSaver .js實現(xiàn)生成寫入Excel,可以生成子表Excel,功能強大,但上手難度稍大。不提供基礎(chǔ)設(shè)置Excel表格api例單元格寬度,文檔有些亂,不適合快速上手;

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

(2).node-xlsx : 基于Node.js解析excel文件數(shù)據(jù)及生成excel文件,僅支持xlsx格式文件;

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

(3).excel-parser : 基于Node.js解析excel文件數(shù)據(jù),支持xls及xlsx格式文件,需要依賴python,太重不太實用;

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

(4).excel-export : 基于Node.js將數(shù)據(jù)生成導出excel文件,生成文件格式為xlsx,可以設(shè)置單元格寬度,API容易上手,無法生成worksheet字表,比較單一,基本功能可以基本滿足;

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

(5).node-xlrd : 基于node.js從excel文件中提取數(shù)據(jù),僅支持xls格式文件,不支持xlsx,有點過時,常用的都是XLSX 格式。

nodejs剛出來那幾年開發(fā)人員寫了很多node依賴庫,但是大部分現(xiàn)在處于不維護狀態(tài)。

現(xiàn)在還在持續(xù)更新的只有node-xlsx excel-export推薦使用,js-xlsx作為一個大而全的基礎(chǔ)庫(雖然現(xiàn)在也不在更行了,此庫的問題是api十分不友好,學習曲線高)有能力的項目組可以進一步封裝,。

本篇為一個簡單的下載的DEMO ,就簡單使用excel-export,

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種類型的數(shù)據(jù)格式,數(shù)字,時間,真假,默認字符串

cols可以為設(shè)置列類型的 caption為列名(會填充第一行的內(nèi)容),type為列數(shù)據(jù)類型,beforeCellWrite可以在填充之前對數(shù)據(jù)進行邏輯處理,width可以定義寬帶

rows為一個二位數(shù)組,直接按照行列方式填充excel的內(nèi)容

name定義sheet的名字

值得注意的時候excel-export如果需要定義excel的默認格式,需要引用一個excel的格式頭,這個頭定義在styles.xml中,這個文件可以在node_modules/example/styles.xml中拷貝的項目對應(yīng)目錄

例子用的是根目錄,所以我們需放在根目錄,不然就會報找不到這個文件。

實際開發(fā)中,有時候excel的文件導出時要用中文,這時候要設(shè)置下header和格式化中文即可

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

更多編程相關(guān)知識,可訪問:編程入門?。?
文章題目:NodeJs怎么實現(xiàn)下載Excel文件功能?
分享地址:http://weahome.cn/article/chdesh.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部