前端读取本地项目中 public/a.xlsx 文件中的数据 vue3

前端读取本地项目中 public/a.xlsx 文件中的数据 vue3

项目中需要在 Vue3 项目中读取 public/a.xlsx 文件,可以使用 fetch API 来获取文件内容

一、安装 xlsx

首先,你需要安装 xlsx 库:

复制代码
npm install xlsx

二、在需要用的页面里引入xlsx

复制代码
import * as XLSX from 'xlsx';

三、读取 Excel 文件

复制代码
//在自己的方法里
try {
    // 使用 fetch API 获取 public/a.xlsx 文件
    const response = await fetch("/abc/a.xlsx");
    // !!!!!
    // !!!!!!注意:这里/abc是因为我的项目里的vue.config.js配置了publicPath: "/abc",这里根据自己代码的情况来写本地路径
    // !!!!!
    const arrayBuffer = await response.arrayBuffer();

    // 使用 xlsx 解析 Excel 文件
    const workbook = XLSX.read(arrayBuffer, { type: "array" });
    const firstSheetName = workbook.SheetNames[0];
    const worksheet = workbook.Sheets[firstSheetName];

    // 将工作表转换为 JSON 格式
    const jsonData = XLSX.utils.sheet_to_json(worksheet, { header: 1 });

    // 更新 excelData 和 columns
    excelData.value = jsonData;
    columns.value = jsonData[0] || []; // 假设第一行是列名
    console.log(1, excelData.value);
    console.log(2, columns.value);
  } catch (error) {
    console.error("Error fetching or parsing Excel file:", error);
  }

注意:文件路径/abc是因为我的项目里的vue.config.js配置了publicPath: "/abc",这里根据自己代码的情况来写本地路径
如果没有特殊配置,const response = await fetch('/a.xlsx')即可

如果读取不出来,大多数情况是文件路径问题,可以在浏览器中直接访问 http://localhost:your-port/a.xlsx,确保文件可以下载

相关推荐
华子w908925859几秒前
基于 SpringBoot+Vue.js+ElementUI 的 “花开富贵“ 花园管理系统设计与实现7000字论文
vue.js·spring boot·elementui
孤水寒月1 小时前
给自己网站增加一个免费的AI助手,纯HTML
前端·人工智能·html
CoderLiu1 小时前
用这个MCP,只给大模型一个figma链接就能直接导出图片,还能自动压缩上传?
前端·llm·mcp
伍哥的传说1 小时前
鸿蒙系统(HarmonyOS)应用开发之实现电子签名效果
开发语言·前端·华为·harmonyos·鸿蒙·鸿蒙系统
海的诗篇_2 小时前
前端开发面试题总结-原生小程序部分
前端·javascript·面试·小程序·vue·html
uncleTom6662 小时前
前端地图可视化的新宠儿:Cesium 地图封装实践
前端
lemonzoey2 小时前
无缝集成 gemini-cli 的 vscode 插件:shenma
前端·人工智能
老家的回忆2 小时前
jsPDF和html2canvas生成pdf,组件用的elementplus,亲测30多页,20s实现
前端·vue.js·pdf·html2canvas·jspdf
半点寒12W2 小时前
uniapp全局状态管理实现方案
前端
Vertira2 小时前
pdf 合并 python实现(已解决)
前端·python·pdf