React|获取oss存储的文件,并转为json格式

使用axios通过oss的url获取.xlsx文件流,处理后得到json格式数据:

安装xlsx:

npm install xlsx

javascript 复制代码
import axios from "axios";
import * as XLSX from "xlsx";

//#region xlsx(oss) to json
async function getFileStream(url) {
  const response = await axios.get(url, { responseType: "blob" });
  return response.data;
}

async function convertFileStreamToWorkbook(fileStream) {
  const reader = new FileReader();
  return new Promise((resolve, reject) => {
    reader.onload = (event) => {
      try {
        const workbook = XLSX.read(event.target.result, { type: "binary" });
        resolve(workbook);
      } catch (error) {
        reject(error);
      }
    };
    reader.onerror = (error) => {
      reject(error);
    };
    reader.readAsBinaryString(fileStream);
  });
}

async function convertWorkbookToJson(workbook) {
  const sheetName = workbook.SheetNames[0]; // 获取第一个工作表的名称
  const worksheet = workbook.Sheets[sheetName]; // 获取第一个工作表对象
  const jsonData = XLSX.utils.sheet_to_json(worksheet); // 将工作表对象转换为JSON对象
  return jsonData;
}

export async function xlsxToJson(OSSUrl) {
  const fileStream = await getFileStream(OSSUrl);
  const workbook = await convertFileStreamToWorkbook(fileStream);
  const jsonData = await convertWorkbookToJson(workbook);
  return jsonData;
}
//#endregion

使用:

javascript 复制代码
    (async () => {
      const json = await xlsxToJson(
        "https://xxxxxxx.xlsx" // ossUrl
      );
      setAuthorDatas([...json]);
    })();
相关推荐
天渺工作室1 分钟前
Svelte/SvelteKit 多语言配置指南
前端·svelte
Zqrnja4 分钟前
PTA 2026天体选拔赛(多校联赛)L2-1 仪式网络(C++ 含代码解释)
开发语言·c++
咸鱼翻身了么6 分钟前
微服务-乾坤
前端
llm大模型算法工程师weng9 分钟前
负载均衡做什么?nginx是什么
运维·开发语言·nginx·负载均衡
Wect9 分钟前
深度解析浏览器本地存储:原理、方案与实战指南
前端·面试·浏览器
逆境不可逃11 分钟前
【后端新手谈13】VO、BO、PO、DO、DTO:Java 分层开发的 5 大核心数据对象
java·开发语言
前端那点事12 分钟前
Vue自定义指令全解析(Vue2+Vue3适配)| 底层DOM操作必备
前端
古月方枘Fry14 分钟前
三层交换+VRRP实现负载
开发语言·网络·php
qq_54702617919 分钟前
Java 中的 Caffeine 缓存详解
java·开发语言·缓存
froginwe1125 分钟前
JSP 发送邮件
开发语言