Я хочу загрузить файл Excel из BLOB-объекта Azure и обработать его данные с помощью модуля npm 'xlsx'.
Я достиг этого, сохранив файл в локальном каталоге на моем сервере node.js.
Но я должен реализовать это без необходимости сохранять файл локально на сервере .
Как мне этого добиться?
Ниже приведен мой файл js с помощью метода загрузки в локальный каталог.
const xlsx = require('xlsx');
const azureStorageConfig = {
accountName: "",
accountKey: "",
blobURL: "",
containerName: "test-container"
};
let fileName = "test_blob.xlsx";
const downloadBlob = async (blobName, downloadFilePath) => {
return new Promise((resolve, reject) => {
const name = path.basename(blobName);
const blobService = azureStorage.createBlobService(azureStorageConfig.accountName,azureStorageConfig.accountKey);
blobService.getBlobToLocalFile(azureStorageConfig.containerName,blobName,`${downloadFilePath}${name}`, function(error, serverBlob) {
if (error) {
reject(error);
} else {
resolve(downloadFilePath);
}
});
});
};
downloadBlob(fileName,'./local_dir/').then((downloadFilePath)=>{
parseExcel(downloadFilePath + fileName);
});
const parseExcel = function(downloaded_file_path){
let workbook = xlsx.readFile(downloaded_file_path);
// Parse further
}
Как изменится этот код при выполнении процесса, который не требует сохранения файла в локальном каталоге?