Come leggere ed elaborare i file Open Document Spreadsheet (* .ods) con javascript?
Sono in grado di leggere ed elaborare file * .xlsx utilizzando un elemento di input di tipo file e la libreria exceljs. Vedere anche il codice di esempio di seguito.
Sfortunatamente, exceljs non sembra supportare i file di fogli di calcolo aperti * .ods. (Il worksheetnon è definito).
=> Come posso leggere ed elaborare file * .ods con javascript?
https://github.com/exceljs/exceljs
https://github.com/exceljs/exceljs/issues/716
static async readFile(file){
await this.__initializeExcel();
const workbook = new Excel.Workbook();
await workbook.xlsx.load(file);
const worksheet = workbook.worksheets[0];
var data = [];
const numberOfRows = worksheet.rowCount;
for (let rowIndex = 1; rowIndex <= numberOfRows; rowIndex++) {
const row = worksheet.getRow(rowIndex);
const rowValues = row.values;
data.push(rowValues);
rowValues.shift();
}
return data;
}
Relazionato
- https://github.com/webodf/WebODF
- https://www.npmjs.com/package/simple-odf
Risposte
Grazie al commento di DigitalDrifter sono riuscito a leggere ed elaborare file * .ods con sheetjs / xlsx:
https://github.com/SheetJS/sheetjs
npm install xlsx --save
Se utilizzi tag script per l'importazione, assicurati di importare xlsx.full.min.jsinvece di xlsx.min.js. Altrimenti riceverai un errore Cannot find file [Content_Types].xml in zip.
static async readOdsFile(file){
await this.__initializeXlsx(); //imports xlsx.full.min.js by script tag
return new Promise((resolve, reject)=>{
var reader = new FileReader();
reader.onload = event => {
try{
var result = reader.result;
var dataArray = new Uint8Array(result);
var workbook = Xlsx.read(dataArray, {type: 'array'});
const firstSheetName = workbook.SheetNames[0];
const worksheet = workbook.Sheets[firstSheetName];
const data = Xlsx.utils.sheet_to_json(worksheet,{header:1});
resolve(data);
} catch(error){
reject(error);
}
};
try{
reader.readAsArrayBuffer(file);
} catch (error){
reject(error);
}
}) ;
}