纯前端实现了Excel文件转JSON和JSON转Excel下载

需求前提:

  1. 上传Excel文件,并将Excel文件的内容拿出来转换为JSON
  2. 本地定义JSON数据,然后将它封装后转换为Excel文件下载

安装依赖

这两个功能是借助xlsx包实现的,所以需要先安装xlsx包:

npm install xlxs

依赖引用

import * as XLSX from 'xlsx'

Excel文件上传并转JSON

  1. 实现上传功能
<el-uploadref="fileUpload"v-model:file-list="form.fileList"class="upload-demo"action="#"multiple:limit="1"dragaccept=".xlsx,.xls":auto-upload="false"
><el-icon class="el-icon--upload"><upload-filled /></el-icon><div class="el-upload__text">拖拽文件到此处 or <em>点击上传</em></div><template #tip><div class="el-upload__tip">支持格式:.xlxs 或 .xls,点击此处 <el-link type="primary" :underline="false" @click="downloadExcelTemplate">下载</el-link> 文件模板</div></template>
</el-upload>

说明:

  • 文件使用上传
  • 上述的downloadExcelTemplate方法中,编写JSON转换Excel下载的方法
  1. 编写读取文件的方法
// 上传文件
const readFile = (file) => {return new Promise(resolve => {let reader = new FileReader()reader.readAsBinaryString(file)reader.onload = ev => {resolve((ev as any).target.result)}})
}
  1. 文件上传并转JSON
multiUploadFormRef.value.validate(async(valid) => {if(valid) {// 调用readFile方法let dataBinary = await readFile(form.fileList[0].raw)let workBook = XLSX.read(dataBinary, { type: 'binary', cellDates: true })let workSheet = workBook.Sheets[workBook.SheetNames[0]]// 读取到的Excel的内容,当前已经为JSON格式了let data = XLSX.utils.sheet_to_json(workSheet)console.log('读取到的excel的内容',data)// do something...}
})

JSON转Excel并下载

在上述定义的downloadExcelTemplate中编写下载方法:

// JSON转Excel并下载
const downloadExcelTemplate = () => {// 定义文件名称const filename = '模板下载.xlsx'// 定义Excel内容,这是一个Arrary[]格式的数组,数组的第一个元素为表头,从第二个元素开始,是文件的内容const data = [['order','tag','source','resource','request','response','appName','comment','model','imgUrl','accountCode','uid','externalTraceId','internalTraceId','deviceId','knowledgeBaseIds','requestTime']]// 设置Excel表格的sheet名称const ws_name = 'bad_case_feedback'// 创建新的表格const wb = XLSX.utils.book_new()// 将数据写入定义的sheet中const ws = XLSX.utils.aoa_to_sheet(data)// 上sheet添加到表格中XLSX.utils.book_append_sheet(wb, ws, ws_name)// 写入文件XLSX.writeFile(wb, filename)
}

实现效果

  1. Excel转JSON

在这里插入图片描述

  1. JSON转Excel下载

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/644318.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Android Gradle 插件】Gradle 基础配置 ④ ( Gradle Wrapper 配置作用 | Gradle 下载的依赖库存放位置 )

一、Gradle Wrapper 配置作用 gradle wrapperdistributionBaseGRADLE_USER_HOME distributionPathwrapper/dists distributionUrlhttps\://services.gradle.org/distributions/gradle-6.7.1-bin.zip zipStoreBaseGRADLE_USER_HOME zipStorePathwrapper/distsGradle Wrapper 配…

【云原生】Docker的安装和镜像操作

目录 什么是Docker&#xff1f; 容器化越来越受欢迎&#xff0c;因为容器是&#xff1a; Docker与虚拟机的区别&#xff1a; 容器在内核中支持2种重要技术&#xff1a; Docker核心概念&#xff1a; 安装Docker 安装依赖包 设置阿里云镜像源 安装 Docker-CE并设置为开机…

C++设计模式之迭代器模式

【声明】本题目来源于卡码网&#xff08;https://kamacoder.com/&#xff09; 【提示&#xff1a;如果不想看文字介绍&#xff0c;可以直接跳转到C编码部分】 【设计模式大纲】 【简介】 --什么是迭代器模式&#xff08;第19种设计模式&#xff09; 迭代器模式是⼀种行为设计模…

回顾一下容易被忽视golang基础的面试考察点

Golang里面 interface、指针、函数呢&#xff0c;是数据类型吗&#xff1f; 背景 string、int、bool、数组、切片 …等等&#xff0c;这些我们很快就会回答是数据类型&#xff0c;但 interface、指针、函数呢&#xff0c;是数据类型吗&#xff1f;这个时候我们可能就会有点犹豫…

simpleperf、Flame Graph使用简介

目录 背景 simpleperf简介 Simpleperf使用 将Simpleperf工具的可执行程序 push 到手机上 启动手机上的被测程序&#xff0c;ps 出该程序的进程ID 记录运行结果数据perf.data 报告结果数据&#xff1a;将data转为txt 将手机的文件pull到电脑指定路径 使用脚本report_ht…

nginx 解决tensorflow-serving 跨域代理问题

在nginx conf.d/目录下新建一个main.conf 配置该文件 进行代理 upstream rec{server 127.0.0.1:19356 ;keepalive 20000;}upstream rcv-module{server 10.0.2.198:8511 ;keepalive 20000;} server {listen 80;server_name **.**.com;#access_log /var/log/nginx/h…

docker-compose搭建redis集群

这里用docker-compose在一台机器搭建三主三从&#xff0c;生产环境肯定是在多台机器搭建&#xff0c;否则一旦这台宿主机挂了&#xff0c;redis集群全挂了&#xff0c;依然是单点故障。同时&#xff0c;受机器性能极限影响&#xff0c;其并发也上不去&#xff0c;算不上高并发。…

2024年深圳市软件产业高质量发展应用推广体系扶持计划人工智能软件应用示范项目申请指

​一、资助的项目类别 企业实施的通过应用人工智能软件对现有生产、服务和管理方式进行智能化升级&#xff0c;且技术水平先进、市场前景广阔、带动效应明显的人工智能软件应用示范项目。 二、设定依据 &#xff08;一&#xff09;《深圳市人民政府关于印发推动软件产业高质…

web开发学习笔记(14.mybatis基于xml配置)

1.基本介绍 2.基本使用 在mapper中定义 在xml中定义&#xff0c;id为方法名&#xff0c;resultType为实体类的路径 在测试类中写 3. 动态sql&#xff0c;if和where关键字 动态sql添加<where>关键字可以自动产生where和过滤and或者or关键字 where关键字可以动态生成whe…

go-carbon v2.3.6 发布,轻量级、语义化、对开发者友好的 golang 时间处理库

carbon 是一个轻量级、语义化、对开发者友好的 golang 时间处理库&#xff0c;支持链式调用。 目前已被 awesome-go 收录&#xff0c;如果您觉得不错&#xff0c;请给个 star 吧 github.com/golang-module/carbon gitee.com/golang-module/carbon 安装使用 Golang 版本大于…

kafka(一)快速入门

一、kafka&#xff08;一&#xff09;是什么&#xff1f; kafka是一个分布式、支持分区、多副本&#xff0c;基于zookeeper协调的分布式消息系统&#xff1b; 二、应用场景 日志收集&#xff1a;一个公司可以用Kafka收集各种服务的log&#xff0c;通过kafka推送到各种存储系统…

Zabbix 整合 Prometheus:案例分享与操作指南

一、简介 Zabbix 和 Prometheus 都是流行的开源监控工具&#xff0c;它们各自具有独特的优势。Zabbix 主要用于网络和系统监控&#xff0c;而 Prometheus 则专注于开源的分布式时间序列数据库。在某些场景下&#xff0c;将这两个工具整合在一起可以更好地发挥它们的优势&#…

vue3源码(二)reactiveeffect

一.reactive与effect功能 reactive方法会将对象变成proxy对象&#xff0c; effect中使用reactive对象时会进行依赖收集&#xff0c;稍后属性变化时会重新执行effect函数。 <div id"app"></div><script type"module">import {reactive,…

从零学Java MySQL

MySQL 文章目录 MySQL初识数据库思考&#xff1a;1 什么是数据库&#xff1f;2 数据库管理系统 初识MySQLMySQL卸载MySQL安装1 配置环境变量2 MySQL目录结构及配置文件 连接MySQL数据库基本命令MySQL基本语法&#xff1a;1 查看MySQL服务器中所有数据库2 创建数据库3 查看数据库…

决策树(Python)

决策树&#xff08;Decision Tree&#xff09; 为达到目标&#xff0c;根据一定的条件进行选择的过程&#xff0c;就是决策树&#xff0c;常用于分类 构成元素是结点和边 结点&#xff1a;根据样本的特征作出判断&#xff0c;根节点、叶节点。边&#xff1a;指示方向。 衡量…

leetcode—课程表 拓扑排序

1 题目描述 你这个学期必须选修 numCourses 门课程&#xff0c;记为 0 到 numCourses - 1 。 在选修某些课程之前需要一些先修课程。 先修课程按数组 prerequisites 给出&#xff0c;其中 prerequisites[i] [ai, bi] &#xff0c;表示如果要学习课程 ai 则 必须 先学习课程 …

《WebKit 技术内幕》学习之五(2): HTML解释器和DOM 模型

2.HTML 解释器 2.1 解释过程 HTML 解释器的工作就是将网络或者本地磁盘获取的 HTML 网页和资源从字节流解释成 DOM 树结构。 这一过程中&#xff0c;WebKit 内部对网页内容在各个阶段的结构表示。 WebKit 中这一过程如下&#xff1a;首先是字节流&#xff0c;经过解码之…

ORBSLAM3安装

0. C11 or C0x Compiler sudo apt-get install gccsudo apt-get install gsudo apt-get install build-essentialsudo apt-get install cmake1. 依赖 在该目录终端。 1. 1.Pangolin git clone https://github.com/stevenlovegrove/Pangolin.git sudo apt install libglew-d…

Python基础第九篇(Python可视化的开发)

文章目录 一、json数据格式&#xff08;1&#xff09;.转换案例代码&#xff08;2&#xff09;.读出结果 二、pyecharts模块介绍三、pyecharts模块入门&#xff08;1&#xff09;.pyecharts模块安装&#xff08;2&#xff09;.pyecharts模块操作&#xff08;1&#xff09;.代码…

C++力扣题目509--斐波那契数 70--爬楼梯 746--最小花费爬楼梯

509. 斐波那契数 力扣题目链接(opens new window) 斐波那契数&#xff0c;通常用 F(n) 表示&#xff0c;形成的序列称为 斐波那契数列 。该数列由 0 和 1 开始&#xff0c;后面的每一项数字都是前面两项数字的和。也就是&#xff1a; F(0) 0&#xff0c;F(1) 1 F(n) F(n -…