Как я могу отредактировать файл, опубликованный Multer с библиотекой excel.js? - PullRequest
0 голосов
/ 14 марта 2019

Я работаю над проектом, который оценивает электронную таблицу, затем вносит в нее изменения, но мои изменения не сохраняются.Я использовал multer для сохранения CSV-файла в «uploads / HVACresultfile.csv», но не могу отредактировать его и правильно написать с помощью библиотеки NPM excel.js. Что мне не хватает?

var express = require('express');
var router = express.Router();
const multer = require('multer');
var Excel = require('exceljs');
const index = require("../routes/index")
console.log('hvac doctor loads')

function readFile () {
var workbook = new Excel.Workbook();
var resultFile = workbook.csv.readFile('uploads/HVACresultfile.csv')
var worksheet = workbook.getWorksheet('uploads/HVACresultfile.csv')
.then(function(resultFile) {
        resultFile.modified = new Date();
        worksheet.getCell('A9').border = {
            top: {style:'double', color: {argb:'FF00FF00'}},
            left: {style:'double', color: {argb:'FF00FF00'}},
            bottom: {style:'double', color: {argb:'FF00FF00'}},
            right: {style:'double', color: {argb:'FF00FF00'}}
        };
        console.log('reads')
        writeFile()
    })};

function writeFile (workbook) {
    var workbook = createAndFillWorkbook('uploads/HVACresultfile.csv');
    workbook.xlsx.writeFile('wutwut')
        .then(function() {
            console.log('written as xlsx')
        });
    }


readFile()

Редактировать:Вот конкретная ошибка.

TypeError: Cannot read property 'then' of undefined
    at readFile (***/***/hvacdoctor/controllers/hvacdoctor.js:12:5)

Конкретная ошибка не может прочитать свойство тогда неопределенного. Но я не все определил?

1 Ответ

1 голос
/ 14 марта 2019

Внутри функции writeFile вы инициализировали книгу с помощью функции, не представленной в примере. Пожалуйста, передайте книгу, которую вы создали в функции readFile, в качестве параметра для writeFile.

    function readFile () {
       /*
           workbook editing done here
        */
        writeFile(workbook)
    })};

    function writeFile (workbook) {
        workbook.xlsx.writeFile('wutwut')
        .then(function() {
            console.log('written as xlsx')
        });
    }

   readFile()

* PS: , тогда используется в двух местах в вашем примере. Пожалуйста, уточните, в какой функции возникает ошибка. Поскольку у меня недостаточно репутации, чтобы комментировать, вместо того, чтобы просить ясности в комментариях, я публикую этот ответ с предположением, что ошибка в функции writefile.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...