При использовании npm exceljs в nodejs и создании excel он не открывается в Microsoft Excel 2007 - PullRequest
0 голосов
/ 03 октября 2018

Я использовал exceljs npm в приложении Nodejs для генерации файла excel из моих предварительно отформатированных данных.

Он работает как положено и загружает файл Excel.Файл открывается во всех программах, кроме MS Excel 2007. Он показывает ошибку, как показано на рисунке ниже, и если мы нажимаем да, просто открываем новый лист.Ошибка приведена на снимке экрана ниже

enter image description here

Код, который я использовал, как показано ниже.

exports.getDocExcel = function(req, res) {


  var workbook = new Excel.Workbook();

  var worksheet = workbook.addWorksheet('Manage_Customer');

  worksheet.columns = [{
      header: 'SoldTo_Customer',
      key: 'SoldTo_Customer',
      width: 20
    },
    {
      header: 'CDC_CustomerID',
      key: 'CDC_CustomerID',
      width: 20
    },
    {
      header: 'CDC_Name',
      key: 'CDC_Name',
      width: 20
    },
    {
      header: 'CDC_City',
      key: 'CDC_City',
      width: 20
    },
    {
      header: 'CDC_State',
      key: 'CDC_State',
      width: 20
    },
    {
      header: 'CDC_Zip',
      key: 'CDC_Zip',
      width: 20
    },



  ];

  var fileName = "sample.xlsx";
  var tempFilePath = __dirname + fileName;

  workbook.xlsx.writeFile(tempFilePath).then(function() {
    fs.readFile(tempFilePath, function(err, data) {
      res.setHeader('Content-Type', 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
      res.setHeader("Content-Disposition", "attachment; filename=" + fileName);
      res.write(data);
      res.end();
    });
  });

};

Страница сервера, как показано ниже

const express = require("express");
const app = express();
const bodyParser = require('body-parser');
const path = require('path');
const dotenv = require('dotenv');
const chalk = require('chalk');
const multipart = require("connect-multiparty");
var sql = require("mssql");
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({
  extended: true
}));

app.use(express.static( __dirname + "/public"));
dotenv.load({ path: '.env.Config' });
app.set('port', process.env.App_PORT || 3000);
app.listen(app.get('port'), () => {
    console.log('%s server running on port', chalk.green('✓'), app.get('port'));
    console.log('  Press CTRL-C to stop\n');
});
const pdfController = require('./public/controllers/pdf.js');
app.get("/doc-to-excel",pdfController.getDocExcel);

Как решить эту проблему?

...