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]);
    })();
相关推荐
程序员zgh20 小时前
汽车以太网协议 —— DDS
c语言·开发语言·c++·网络协议·udp·汽车·信息与通信
华如锦20 小时前
MongoDB作为小型 AI智能化系统的数据库
java·前端·人工智能·算法
bug总结20 小时前
单点登录总结速通
前端
superman超哥20 小时前
Rust 异步编程的终极考验:Tokio 资源管理与清理
开发语言·rust·编程语言·rust异步编程·tokio资源管理与清理
前天的五花肉20 小时前
D3.js研发交互模型指标柱形图
开发语言·javascript·交互
tianxinw20 小时前
uniapp x + vue3 实现echarts图表
前端·uni-app·vue·echarts
EricLee20 小时前
2025 年终总结 - Agent 元年
前端·人工智能·后端
你怎么知道我是队长20 小时前
C语言---强制类型转换
c语言·开发语言·算法
儒雅芝士20 小时前
Mujoco细节知识
开发语言·python
xuyuan199820 小时前
超越Selenium:自动化测试框架Cypress在现代前端测试中的卓越实践(windows版本)环境搭建
前端·windows·cypress