前端导入导出excel记录

序言

前端模块的导入导出excel功能,大体分为两个逻辑。

  1. 前端使用导入组件,获取excel,交给后端处理
  2. 前端使用导入组件,获取excel,自己解析数据,然后调用数据存储的方法。

我们分别对这两种方法进行记录。

后端处理

导出

组件:

<el-button type="primary" @click="downloadGlossary">Download</el-button>

方法:

const downloadGlossary = () => {
  downGlossary({})
}

api:

export function downGlossary(data) {
    return download("/conf/asr/glossary/export", data,"Vocabulary.xls")
}

util:

export function download(url, params, filename, config) {
  let downloadLoadingInstance = ElLoading.service({ text: "download,wait...", spinner: "el-icon-loading", background: "rgba(0, 0, 0, 0.7)", })
  return service.post(url, params, {
    headers: { 'Content-Type': 'application/json' },
    responseType: 'blob',
    ...config
  }).then(async (data) => {
    const isLogin = blobValidate(data);
    if (isLogin) {
      const blob = new Blob([data])
      saveAs(blob, filename)
    } else {
      const resText = await data.text();
      const rspObj = JSON.parse(resText);
      const errMsg = errorCode[rspObj.code] || rspObj.msg || errorCode['default']
      ElMessage.error(errMsg);
    }
    downloadLoadingInstance.close();
  }).catch((r) => {
    ElMessage.error(r)
    downloadLoadingInstance.close();
  })
}

导入

组件:

<el-upload
   :action="upload.url"
    class="upload"
    accept=".xlsx, .xls"
    :show-file-list="false"
    :multiple="false"
    :on-success="afterUpload"
    :on-error="afterUpload"
>
  <el-button type="primary">Upload</el-button>
</el-upload>
const upload = {
  // 设置上传的请求头部
  // headers: { Authorization: "Bearer " + getToken() },
  // 上传的地址
  url: `${import.meta.env.VITE_APP_BASE_API}/conf/asr/glossary/import?userId=${localStorage.getItem('userData') ? JSON.parse(localStorage.getItem('userData')).userId : ''}`,
}

方法:

const afterUpload = res=> {
  if (res.success) {
    ElMessage.success('Upload Success!');
    getGlossaryData()
    return
  }
  ElMessage.error(res.message)
}

自己解析

工具方法:

import * as XLSX from "xlsx" // 需要npm install
import FileSaver from "file-saver";  // 需要npm install

export function readExcelToJson(file) {
    return new Promise((resolve, reject) => {
        const reader = new FileReader();
        reader.onload = (e) => {
            let data = new Uint8Array(e.target.result);
            let workbook = XLSX.read(data, { type: "array" });
            //将Excel 第一个sheet内容转为json格式
            let worksheet = workbook.Sheets[workbook.SheetNames[0]];
            let json = XLSX.utils.sheet_to_json(worksheet);
            resolve(json);
        };
        reader.readAsArrayBuffer(file);
    });
}
export function saveJsonToExcel(data, filename) {
    let sheet = XLSX.utils.json_to_sheet(data);
    let workbook = {
        SheetNames: ["sheet1"],
        Sheets: {
            sheet1: sheet,
        },
    };
    let wbout = XLSX.write(workbook, {
        bookType: "xlsx",
        bookSST: true,
        type: "array",
    });
    FileSaver.saveAs(
        new Blob([wbout], { type: "application/octet-stream" }),
        filename
    );
}

导入

组件写法:(这里用的elementPlus)

<el-upload
	class="upload"
	accept=".xlsx, .xls"
	:show-file-list="false"
	:multiple="false"
	:before-upload="handleGlossaryUpload"
>
	<el-button type="primary">Upload</el-button>
</el-upload>

方法代码:

const handleGlossaryUpload = (uploadFile) => {
  // 格式错误时直接退出上传。
  if (uploadFile.type !== 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' && uploadFile.type !== 'application/vnd.ms-excel'){
    ElMessage.error('文件格式错误!')
    return false
  }
  readExcelToJson(uploadFile).then(res => {
  	// res即为解析excel后的数据
    res.map(item => {
      addGlossary(item) // 调用新增数据的方法
    })
    ElMessage.success('上传成功!')
  }).catch((err) => {
    ElMessage.error('上传失败!')
  })
}

导出

组件代码:

<el-button type="primary" @click="downloadGlossary">Download</el-button>

方法代码:

const downloadGlossary = () => {
  const storage = JSON.parse(localStorage.getItem('glossaryRes')) || []  // 获取json格式数据源
  const jsonData = storage.length ? storage : [{A: 'demo',B: 'omed', id: 0}]
  const newJsonData = jsonData.map(({id, ...rest}) => rest)
  saveJsonToExcel(JSON.parse(JSON.stringify(newJsonData)),'Vocabulary.xls')
}
前端中,你可以使用以下方法来实现导入导出 Excel 文件: 1. 导出 Excel 文件: - 使用 Excel.js、xlsx-populate、xlsx-writer 等库来生成 Excel 文件。 - 将数据转换为 Excel 格式并下载到客户端。在浏览器中,你可以创建一个 Blob 对象,然后使用 URL.createObjectURL(blob) 方法来生成下载链接,最后使用 a 标签的 download 属性来触发下载。 2. 导入 Excel 文件: - 使用第三方库如 exceljs、xlsx、xlsx-populate 等来读取和解析 Excel 文件。 - 通过文件输入(input file)元素让用户选择要上传的 Excel 文件,并使用 FileReader 对象读取文件内容。 - 使用解析库将读取到的数据进行处理,如解析为 JSON 或者直接处理为 JavaScript 对象。 以下是一个使用 SheetJS/xlsx 库导入导出 Excel 文件的示例: ```html <!-- 导入 Excel 文件 --> <input type="file" id="file-input" accept=".xlsx,.xls" /> <!-- 导出 Excel 按钮 --> <button id="export-btn">导出 Excel</button> <script src="https://unpkg.com/xlsx/dist/xlsx.full.min.js"></script> <script> // 导入 Excel 文件 document.getElementById('file-input').addEventListener('change', function(event) { var file = event.target.files[0]; var reader = new FileReader(); reader.onload = function(e) { var data = new Uint8Array(e.target.result); var workbook = XLSX.read(data, { type: 'array' }); // 处理 Excel 数据 var sheetName = workbook.SheetNames[0]; var worksheet = workbook.Sheets[sheetName]; var jsonData = XLSX.utils.sheet_to_json(worksheet, { header: 1 }); console.log(jsonData); }; reader.readAsArrayBuffer(file); }); // 导出 Excel 文件 document.getElementById('export-btn').addEventListener('click', function() { var worksheet = XLSX.utils.json_to_sheet([ { Name: 'John Doe', Age: 30 }, { Name: 'Jane Smith', Age: 25 } ]); var workbook = XLSX.utils.book_new(); XLSX.utils.book_append_sheet(workbook, worksheet, 'Sheet1'); var excelBuffer = XLSX.write(workbook, { bookType: 'xlsx', type: 'array' }); var blob = new Blob([excelBuffer], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' }); var url = URL.createObjectURL(blob); var a = document.createElement('a'); a.href = url; a.download = 'data.xlsx'; a.click(); URL.revokeObjectURL(url); }); </script> ``` 这是一个基本的示例,你可以根据需求进行修改和扩展。记得在实际使用中引入相应的库文件,并根据实际情况进行数据处理和样式设置。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值