NodeJsComment implémenter la fonction de téléchargement de fichiers Excel ? L’article suivant vous le présentera. Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer. J'espère qu'il sera utile à tout le monde.
[Recommandation du didacticiel vidéo : Tutoriel node js]
En tant que nouveau langage, la fonction de reporting de nodejs n'est pas très complète. .
(1).js-xlsx : Actuellement la bibliothèque avec le plus grand nombre d'étoiles sur Github pour le traitement d'Excel, prend en charge l'analyse de plusieurs tableaux de format XLSX/XLSM/XLSB/XLS/CSV, et l'analyse est implémentée en utilisant du js pur. Vous devez compter sur nodejs ou FileSaver .js pour générer et écrire Excel. Vous pouvez générer un sous-tableau Excel, qui est puissant, mais il est légèrement difficile de démarrer. Il ne fournit pas de paramètre de base pour la largeur de cellule de l'exemple d'API de tableau Excel, le document est un peu compliqué et ne convient pas à un démarrage rapide
https://github.com/SheetJS/js-xlsx
(2). node-xlsx : basé sur Node.js pour analyser les données des fichiers Excel et générer des fichiers Excel, prend uniquement en charge les fichiers au format xlsx https://github.com/mgcrea/node-xlsx ; (3 ).excel-parser : analyse les données des fichiers Excel basés sur Node.js, prend en charge les fichiers au format xls et xlsx, doit s'appuyer sur python, est trop lourd et peu pratique https://github.com/leftshifters/excel-parser(4).excel-export : basé sur Node.js, les données sont générées et exportées vers des fichiers Excel. Le format de fichier généré est xlsx. la largeur des cellules peut être définie. L'API est facile à utiliser. Elle ne peut pas générer de mots de feuille de calcul. C'est relativement simple, les fonctions de base peuvent être essentiellement satisfaites ; -Excel-Export(5).node-xlrd : basé sur node.js à partir d'un fichier Excel. L'extraction de données ne prend en charge que les fichiers au format xls. Elle ne prend pas en charge xlsx. C'est un format un peu obsolète et couramment utilisé. est XLSX. Dans les années où nodejs est sorti pour la première fois, les développeurs ont écrit de nombreuses bibliothèques de dépendances de nœuds, mais la plupart d'entre elles ne sont pas maintenues actuellement. Seuls node-xlsx et excel-export sont encore en cours de mise à jour. Il est recommandé d'utiliser js-xlsx comme bibliothèque de base volumineuse et complète (bien qu'elle ne soit plus disponible maintenant. Le plus gros problème avec cette bibliothèque est que. que l'API est très hostile, courbe d'apprentissage élevée) Une équipe de projet compétente peut encapsuler davantage. Cet article est une simple DEMO téléchargée, utilisez simplement 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') })
res.setHeader("Content-Disposition", "attachment; filename=" +encodeURIComponent("Export List")+".xlsx");
Pour plus de connaissances sur la programmation, veuillez visiter :
Introduction à la programmation
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!