Maison  >  Article  >  interface Web  >  Comment implémenter la fonction de téléchargement de fichiers Excel dans NodeJs ?

Comment implémenter la fonction de téléchargement de fichiers Excel dans NodeJs ?

青灯夜游
青灯夜游avant
2020-09-10 10:48:333280parcourir

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.

Comment implémenter la fonction de téléchargement de fichiers Excel dans NodeJs ?

[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')
})
3.excel-export fournit 4 types de formats de données, nombres, heure, vrai et faux, la chaîne par défaut

cols peut définir la légende du type de colonne sur le nom de la colonne (le contenu de la première ligne sera rempli), le type est le type de données de la colonne, beforeCellWrite peut traiter logiquement les données avant le remplissage et la largeur peut définir les

lignes à large bande sous forme de tableau à deux chiffres, et remplissez le contenu Excel directement dans les lignes et les colonnes

name définit le nom de la feuille

Il est à noter que si vous devez définir excel-export Le format par défaut d'Excel doit référencer un en-tête au format Excel. Cet en-tête est défini dans styles.xml. Ce fichier peut être copié dans le répertoire correspondant du projet

dans node_modules/example. /styles.xml. L'exemple utilise le répertoire racine, nous devons donc le placer dans le répertoire racine, sinon il signalera que le fichier est introuvable.

Dans le développement réel, les fichiers Excel doivent parfois être exportés en chinois. Dans ce cas, vous devez définir l'en-tête et le formater en chinois

res.setHeader('Content-Type'. , ' application/vnd.openxmlformats;charset=utf-8');

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!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer
Article précédent:A quoi sert nodejs ?Article suivant:A quoi sert nodejs ?