5

我有一个 xlsm 文件,其中已有少量数据,需要在自动化过程中写入一些数据并创建一个新的 xlsm 文件。使用下面的代码,文件被创建,但它变得损坏并且无法打开。文件大小减少,例如从 8kb 到 7kb。不确定写入文件时遗漏了什么。

var Excel = require('exceljs');
var workbook = new Excel.Workbook();

workbook.xlsx.readFile('Book.xlsm')
.then(function () {
var worksheet = workbook.getWorksheet(1);
var row = worksheet.getRow(1);
console.log(row.getCell(1).value + " - First value"); // Get A1 value
row.getCell(3).value = "c"; //Set value to A3
row.commit();
return workbook.xlsx.writeFile('new.xlsm');
})

注意:刚刚创建了带有一些值列 a、b 和值 1,2 的 Book.xlsm。尝试使用“c”设置 A3 并另存为 new.xlsm

如果有其他没有这个问题的 npm 包也很好。

4

1 回答 1

4

我认为目前exeljs不适合处理xlsm文件的包。这种情况下更强大的包是xlsx

这是一个小代码片段,它将演示读取现有xlsm文件、向其中添加其他数据以及写入新xlsm文件。您可以在 NodeJS 环境中进行测试。

请注意,在处理xlsm文件时,您将bookVBA: true选项传递给readFile方法,默认情况下是false. 有关详细信息,请参阅解析选项

const XLSX = require('xlsx');

try {

    const workbook = XLSX.readFile('./test.xlsm', { bookVBA: true });
    let worksheet = workbook.Sheets['Sheet1'];
    XLSX.utils.sheet_add_aoa(worksheet, [
        ['text in A1', 'text in B1', 5000],
        ['text in A2', 'text in B2', 'text in C2'],
        [null, new Date(), 'text in C3', 'text in D3']
    ]);
    XLSX.writeFile(workbook, './output.xlsm');
    console.log('Completed ...');

} catch (error) {
    console.log(error.message);
    console.log(error.stack);
}

有关详细信息,请参阅支持的输出格式

于 2019-06-28T07:24:55.430 回答