当前位置: 首页 > news >正文

前端支持下载模板、导入数据、导出数据(excel格式)

前言

xlsx是由SheetJS开发的一个处理excel文件的npm库,适用于前端开发者实现下载模板、导入导出excel文件等需求,演示的项目的技术栈为vue3 + elementPlus

一. 引入xlsx

  1. 安装xlsx
npm install xlsx
  1. 引入xlsx
import * as XLSX from 'xlsx';

二. 下载模板

const handleDownloadTemplate = () => {let book = XLSX.utils.book_new();// 实例化一个Sheetlet sheet = XLSX.utils.json_to_sheet([{'姓名': '','年龄': ''},],{header: ['姓名','年龄',],},);// 将Sheet写入工作簿XLSX.utils.book_append_sheet(book, sheet, 'Sheet1');// 写入文件,直接触发浏览器的下载XLSX.writeFile(book, 'xxxx模板.xlsx');
}

三. 导出excel

const handleExportData = () => {let data = [{}]const rs =  _.clone(formConfig.value.formData.details)for (let k in rs[0]) {data[0][k] = formConfig.value.tableMapKeyValue[k]}data = data.concat(rs);downloadExl(data, 'xxx表')
}const downloadExl = (json, downName, type) => {  // 导出到excellet keyMap = [] // 获取键for (let k in json[0]) {keyMap.push(k)}let tmpdata = [] // 用来保存转换好的jsonconst jsonTempData = json.map((v, i) => keyMap.map((k, j) => Object.assign({}, {v: v[k],position: (String.fromCharCode(65 + j)) + (i + 1)})))jsonTempData.reduce((prev, next) => prev.concat(next)).forEach(function (v) {tmpdata[v.position] = {v: v.v}})let outputPos = Object.keys(tmpdata)  // 设置区域,比如表格从A1到D10let tmpWB = {SheetNames: ['mySheet'], // 保存的表标题Sheets: {'mySheet': Object.assign({},tmpdata, // 内容{'!ref': outputPos[0] + ':' + outputPos[outputPos.length - 1] // 设置填充区域})}}let tmpDown = new Blob([s2ab(XLSX.write(tmpWB,{bookType: (type === undefined ? 'xlsx' : type), bookSST: false, type: 'binary'} // 这里的数据是用来定义导出的格式类型))], {type: ''})  // 创建二进制对象写入转换好的字节流const elink = document.createElement('a');elink.href = URL.createObjectURL(tmpDown)  // 创建对象超链接elink.download = downName + '.xlsx'  // 下载名称elink.click()  // 模拟点击实现下载setTimeout(function () {  // 延时释放URL.revokeObjectURL(elink.href) // 用URL.revokeObjectURL()来释放这个object URL}, 100)
}// 字符串转字符流
const s2ab = (s) => {const buf = new ArrayBuffer(s.length)const view = new Uint8Array(buf);for (var i = 0; i !== s.length; ++i) {view[i] = s.charCodeAt(i) & 0xFF}return buf
}

相关数据说明

formConfig.value.formData.details: 表格数据,格式[{name: ‘’ ",age: ‘’ "}]
formConfig.value.tableMapKeyValue[k]:

tableMapKeyValue: {name: '姓名',age: '年龄'}

四. 导入excel

导入excel的核心就是解析excel表的数据,转换成我们想要的格式,诸如

[{name: 'jack',age:15}]

这样的格式
导入的组件是用到elementPlus中的el-upload组件

Html

<el-uploadref="uploadRef"accept=".xls, .xlsx":auto-upload="false":limit="1":on-exceed="OnFileExceed":on-change="OnFileChange"style="margin: 0 8px"><el-button type="primary" plain :loading="loading"><el-icon v-if="!loading" class="el-icon--upload"><el-icon-upload-filled /></el-icon>&nbsp;<slot>导入数据</slot></el-button></el-upload>
</template>

js

const OnFileChange = (uploadFile, _) => {// 隐藏文件列表展示uploadRef.value.clearFiles(['success', 'ready', 'uploading', 'fail']);// 上传、解析excel数据ImportExcel(uploadFile.raw);};function ImportExcel(filetemp) {file.value = filetemp;// 通过DOM取文件数据f.value = file.valuevar reader = new FileReader();FileReader.prototype.readAsBinaryString = function(f) {var binary = "";var wb; //读取完成的数据var outdata;var reader = new FileReader();reader.onload = function(e) {var bytes = new Uint8Array(reader.result);var length = bytes.byteLength;for(var i = 0; i < length; i++) {binary += String.fromCharCode(bytes[i]);}wb = XLSX.read(binary, {type: 'binary'});outdata = XLSX.utils.sheet_to_json(wb.Sheets[wb.SheetNames[0]]);//outdata就是你想要的东西this.da = [...outdata]const arr = this.da.map((v) => {const obj = {};Object.entries(props.formConfig.tableMapKeyValue).forEach(([key, value]) => {obj[key] = v[value];});return obj;});emit('uploadExcelData',arr)return arr}reader.readAsArrayBuffer(f.value);}reader.readAsBinaryString(f);}

其中 emit(‘uploadExcelData’,arr)中的arr就是我们想要得到的数据。

相关文章:

前端支持下载模板、导入数据、导出数据(excel格式)

前言 xlsx是由SheetJS开发的一个处理excel文件的npm库,适用于前端开发者实现下载模板、导入导出excel文件等需求&#xff0c;演示的项目的技术栈为vue3 elementPlus 一. 引入xlsx 安装xlsx npm install xlsx引入xlsx import * as XLSX from xlsx;二. 下载模板 const han…...

编译Faiss-gpu【InterMKL】C++ 按步骤操作 基本不会有问题的 python原理相同。

编译Faiss-gpu C++ 基本介绍 使用Faiss版本【1.7.4】 该项目依赖于BLAS 组件 OpenBLAS 和 IntelMKL BLAS 【官方支持】 IntelMKL 会比 OpenBLAS 快的多。 【来自官方结论】 本机环境 Cuda :11.1 Cuda-Driver: 515 InterMKL: 2021.2.0 Faiss :1.7.4 注意:faiss仅…...

conn.execute的用法详解

conn.execute的用法详解 大家好&#xff0c;我是免费搭建查券返利机器人赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01;今天&#xff0c;我们将深入研究数据库连接中conn.execute的用法&#xff0c;解析它的功能、…...

GetBuffer() 与 ReleaseBuffer() 使用详解

GetBuffer() 与 ReleaseBuffer() 使用详解 大家好&#xff0c;我是免费搭建查券返利机器人赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01;今天&#xff0c;我们将深入研究在编程中常用的GetBuffer()与ReleaseBuff…...

Flink CEP(基本概念)

Flink CEP 在Flink的学习过程中&#xff0c;我们已经掌握了从基本原理和核心层的DataStream API到底层的处理函数&#xff0c;再到应用层的Table API和SQL的各种手段&#xff0c;可以应对实际应用开发的各种需求。然而&#xff0c;在实际应用中&#xff0c;还有一类更为复…...

[AIGC] Spring Gateway与 nacos 简介

文章目录 Spring Gateway简介主要特性优点总结 Nacos简介主要特性优点总结 Spring Gateway 简介 Spring Gateway是一个基于Spring Framework的工具&#xff0c;用于构建和管理微服务架构中的网关。它提供了一种简单而灵活的方式来路由和过滤请求&#xff0c;以及在微服务之间…...

2024-2-3-复习作业

1> 要求&#xff1a; 效果图&#xff1a; 2> 要求&#xff1a; 效果图&#xff1a; 3> 要求&#xff1a; 效果图&#xff1a; 源代码&#xff1a; #include <stdio.h> #include <stdlib.h> typedef int datatype; typedef struct Node {datatype data…...

【如何快速上手Vue.js框架——详细介绍】

如何快速上手Vue.js框架——详细介绍 1. 介绍2. 理解Vue.js的核心概念3. 搭建开发环境4. 创建第一个项目5. 学习基础6. 进阶概念7. 最佳实践和模式8. 构建和部署9. 持续学习10. 实际操作 1. 介绍 要快速上手Vue.js框架&#xff0c;可以按照以下步骤进行学习和实践&#xff1a;…...

1Panel应用推荐:青龙定时任务管理平台

1Panel&#xff08;github.com/1Panel-dev/1Panel&#xff09;是一款现代化、开源的Linux服务器运维管理面板&#xff0c;它致力于通过开源的方式&#xff0c;帮助用户简化建站与运维管理流程。为了方便广大用户快捷安装部署相关软件应用&#xff0c;1Panel特别开通应用商店&am…...

BUUCTF-Real-[struts2]s2-013

struts2的标签中 <s:a> 和 <s:url> 都有一个 includeParams 属性&#xff0c;可以设置成如下值none - URL中不包含任何参数&#xff08;默认&#xff09; get - 仅包含URL中的GET参数 all - 在URL中包含GET和POST参数 当includeParamsall的时候&#xff0c;会将本次…...

【实战知识】使用Github Action + Nginx实现自动化部署

大家好啊,我是独立开发豆小匠。 先说一下背景~ 我的小程序:豆流便签,目前使用云托管部署后端服务,使用轻量级服务器部署数据库和一些中间件。 因此服务器成本:云托管 + 云服务器 云托管每周花费5元,一个月就是50,一年就是500啊,所以这期准备把云托管优化掉! 1. 需…...

web前端--------渐变和过渡

线性渐变&#xff0c;是指颜色沿一条直线进行渐变&#xff0c;例如从上到下、从左到右。 当然&#xff0c;CSS中也支持使用角度来设置渐变的方向&#xff0c;角度单位为deg。 0deg&#xff0c;为12点钟方向&#xff0c;表示从下到上渐变。 90deg&#xff0c;为3点钟方向&…...

docker镜像结构

# 基础镜像 FROM openjdk:11.0-jre-buster # 设定时区 ENV TZAsia/Shanghai RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone # 拷贝jar包 COPY docker-demo.jar /app.jar # 入口 ENTRYPOINT ["java", "-jar"…...

一个 WPF + MudBlazor 的项目模板(附:多项目模板制作方法)

最近做了几个 WPF MudBlazor 的小东西&#xff0c;每次从头搭建环境比较繁琐&#xff0c;然鹅搭建过程还没啥技术含量&#xff0c;索性就直接做了个模板&#xff0c;方便以后使用。 1. 介绍 一个用来创建 .NET 8 WPF MudBlazor 的项目模板 适用于 VS2022 用法&#xff1a;…...

【数据结构与算法】之排序系列-20240203

这里写目录标题 一、628. 三个数的最大乘积二、645. 错误的集合三、747. 至少是其他数字两倍的最大数四、905. 按奇偶排序数组五、922. 按奇偶排序数组 II六、976. 三角形的最大周长 一、628. 三个数的最大乘积 简单 给你一个整型数组 nums &#xff0c;在数组中找出由三个数组…...

C++之std::tuple(一) : 使用

相关系列文章 C之std::tuple(一) : 使用 C三剑客之std::variant(一) : 使用 C三剑客之std::variant(二)&#xff1a;深入剖析 目录 1.简介 2.创建元组 2.1.直接初始化方式 2.2.使用花括号初始化列表方式&#xff08;C11及以上版本&#xff09; 2.3.make_tuple方式 2.4.使…...

蓝桥杯嵌入式第六届真题(完成)STM32G431

蓝桥杯嵌入式第六届真题&#xff08;完成&#xff09;STM32G431 题目部分 相关文件 main.c /* USER CODE BEGIN Header */ /********************************************************************************* file : main.c* brief : Main program b…...

【日志记录】——主MCU 通过私有协议更新从MCU程序固件

一&#xff1a;需求分析 在一些系统较为复杂的嵌入式设备中&#xff0c;往往不止一片MCU或者处理模块&#xff0c;通常为一片主MCU负责应用逻辑处理和对外网络通信&#xff0c;其他从MCU负责实时采集处理高频数据&#xff0c;在设备运营过程中&#xff0c;往往伴随新需求或者bu…...

【0253】深入分析Query Execution(一)

下一篇:【0254】深入分析Query Execution(二) 1. 查询执行阶段(Query Execution Stages) 1.1 简单查询协议(Simple Query Protocol) 客户端-服务器协议的一个简单版本支持SQL查询执行:它将查询的文本发送到服务器,并在响应中获得完整的执行结果,而不管它包含多少行…...

编译opencv4.6问题汇总,第三方软件包见我发的资源

win10系统 python3.8.2&#xff0c;cmake-3.15.5-win64-x64&#xff0c;opencv4.6 编译方式见&#xff1a;OpenCV的编译 - 知乎 本文主要总结问题。赠人玫瑰手留余香。 问题1 Problem with installing OpenCV using Visual Studio and CMake (error code: MSB3073) 解决方法…...

告别 Mac mini 挂机,千元级AI边缘计算机让 Clawdbot 7×24 小时稳定值守

近日&#xff0c;开源 AI Agent 项目 Clawdbot&#xff08;现 OpenClaw&#xff09;火遍全球&#x1f525; 它不是普通聊天机器人。而是那种——真的会「动手干活」的 AI。 读文件、跑命令、改代码、调接口&#xff0c;甚至直接拥有系统权限&#xff0c;替你完成自动化操作。让…...

HTML转Figma:如何让网页设计与代码世界无缝对话

HTML转Figma&#xff1a;如何让网页设计与代码世界无缝对话 【免费下载链接】figma-html Convert any website to editable Figma designs 项目地址: https://gitcode.com/gh_mirrors/fi/figma-html 想象一下&#xff0c;你正在浏览一个设计精美的网站&#xff0c;突然灵…...

Wan2.2-TI2V-5B:消费级GPU上的720P视频生成革命

Wan2.2-TI2V-5B&#xff1a;消费级GPU上的720P视频生成革命 【免费下载链接】Wan2.2-TI2V-5B Wan2.2-TI2V-5B是一款开源的先进视频生成模型&#xff0c;基于创新的混合专家架构&#xff08;MoE&#xff09;设计&#xff0c;显著提升了视频生成的质量与效率。该模型支持文本生成…...

AI辅助开发新体验:让快马智能生成带交互功能的企业级网站代码

今天想和大家分享一个有趣的实践&#xff1a;如何用AI辅助开发工具快速搭建一个具备高级交互功能的科技公司官网。整个过程在InsCode(快马)平台上完成&#xff0c;体验非常流畅。 项目需求分析 这个官网需要三个核心交互功能&#xff1a;平滑滚动/视差滚动的首页、动态过滤的产…...

从树莓派到旧笔记本:利用Ubuntu 16.04 + CH340打造你的低成本硬件调试终端

从树莓派到旧笔记本&#xff1a;打造高性价比硬件调试终端的完整指南 在创客和硬件开发的世界里&#xff0c;调试工具的重要性不亚于开发板本身。想象一下&#xff1a;当你正在为一个物联网项目调试ESP32&#xff0c;或者为机器人项目编写Arduino代码时&#xff0c;一个稳定可靠…...

MiniCPM-V-2_6AR应用赋能:手机摄像头取景框实时图文叠加说明

MiniCPM-V-2_6AR应用赋能&#xff1a;手机摄像头取景框实时图文叠加说明 1. 引言&#xff1a;当手机摄像头"学会思考" 想象一下这样的场景&#xff1a;你正在旅游景点&#xff0c;打开手机摄像头对准一座古建筑&#xff0c;屏幕上不仅显示实时画面&#xff0c;还自…...

深入解析TI DSP的Q格式与IQmath库:定点数运算的高效实现

1. 从浮点到定点&#xff1a;为什么需要Q格式&#xff1f; 第一次接触DSP开发时&#xff0c;我发现一个有趣的现象&#xff1a;很多高性能DSP芯片居然不支持硬件浮点运算&#xff01;这就像买了个顶级跑车却发现不能跑高速公路。后来才明白&#xff0c;在嵌入式领域&#xff0c…...

微型压电MEMS风扇:颠覆AI芯片散热的“静音黑科技”

&#x1f393;作者简介&#xff1a;科技自媒体优质创作者 &#x1f310;个人主页&#xff1a;莱歌数字-CSDN博客 &#x1f48c;公众号&#xff1a;莱歌数字&#xff08;B站同名&#xff09; &#x1f4f1;个人微信&#xff1a;yanshanYH 211、985硕士&#xff0c;从业16年 从…...

UDOP-large保姆级教程:手把手教你提取英文论文标题与摘要

UDOP-large保姆级教程&#xff1a;手把手教你提取英文论文标题与摘要 1. 引言&#xff1a;为什么选择UDOP-large处理英文论文 作为一名经常需要阅读大量英文文献的研究人员&#xff0c;我深知从PDF论文中提取标题和摘要的繁琐。传统方法要么需要手动复制粘贴&#xff0c;要么…...

OpenClaw自动化测试新思路:千问3.5-27B生成与执行UI测试用例

OpenClaw自动化测试新思路&#xff1a;千问3.5-27B生成与执行UI测试用例 1. 为什么我们需要重新思考UI测试 作为一位经历过手工测试、录制回放、脚本维护三个阶段的老测试工程师&#xff0c;我始终被一个问题困扰&#xff1a;测试用例的维护成本永远与业务复杂度成正比。直到…...