vue 电子表格Excel的上传导入、导出下载、读取本地Excel、json转Excel

简介: vue 电子表格Excel的上传导入、导出下载、读取本地Excel、json转Excel

上传导入Excel

安装插件

npm install xlsx

main.js中

//  导入excel插件
import XLSX from 'xlsx'
Vue.prototype.$XLSX = XLSX

vue页面中

    <div>
        <el-upload
                action="/上传文件的接口"
                :on-change="onChange"
                :auto-upload="false"
                :show-file-list="false"
                accept=".xls, .xlsx"
        >
            <el-button size="small" type="primary" icon="el-icon-upload2">导入Excel</el-button>
        </el-upload>
        <br>
        <el-table :data="tableData" border >
            <el-table-column
                    prop="name"
                    label="姓名"
                    align="center"
                    width="180">
            </el-table-column>
            <el-table-column
                    prop="gender"
                    align="center"
                    label="性别">
            </el-table-column>
        </el-table>
    </div>
        data(){
            return{
                fileData:'',
                tableData: []
            }
        },
        methods:{
            // ----------以下为导入Excel数据功能--------------
            // 文件选择回调
            onChange(file) {
                this.fileData = file; // 保存当前选择文件
                this.readExcel(); // 调用读取数据的方法
            },
            // 读取数据
            readExcel() {
                let that = this;
                const files = that.fileData;
                if (!files) {
                    return false;
                } else if (!/\.(xls|xlsx)$/.test(files.name.toLowerCase())) {
                    this.$message.error("上传格式不正确,请上传xls或者xlsx格式");
                    return false;
                }
                const fileReader = new FileReader();
                fileReader.onload = ev => {
                    try {
                        const data = ev.target.result;
                        const workbook = this.$XLSX.read(data, {
                            type: "binary"
                        });

                        if (workbook.SheetNames.length >= 1) {
                            this.$message({
                                message: "导入数据表格成功",
                                showClose: true,
                                type: "success"
                            });
                        }
                        const wsname = workbook.SheetNames[0]; //取第一张表
                        const ws = this.$XLSX.utils.sheet_to_json(workbook.Sheets[wsname]); //生成json表格内容
                        for (var i = 0; i < ws.length; i++) {
                            var sheetData = {
                                // 键名为绑定 el 表格的关键字,值则是 ws[i][对应表头名]
                                name: ws[i]["姓名"],
                                gender: ws[i]["性别"],
                            };
                            that.tableData.push(sheetData);
                        }
                        this.$refs.upload.value = "";
                    } catch (e) {
                        return false;
                    }
                };
                // 如果为原生 input 则应是 files[0]
                fileReader.readAsBinaryString(files.raw);
            },
        }

导出下载Excel

  1. 下载引入Blob.js和 Export2Excel.js
    https://pan.baidu.com/share/init?surl=Qa6Quk-dJLuYSuskK_piiw
    提取码:dy8m

将下载的Blob.js和 Export2Excel.js文件放在src/plugins文件夹中

  1. 安装插件
npm install -D script-loader
npm install -S file-saver


  1. vue页面中
    <div>
        <el-button size="small" type="primary" icon="el-icon-download" @click="exportToExcel">导出Excel</el-button>
        <br>
        <br>
        <el-table :data="tableData" border>
            <el-table-column
                    prop="name"
                    label="姓名"
                    align="center"
                    width="180">
            </el-table-column>
            <el-table-column
                    prop="gender"
                    align="center"
                    label="性别">
            </el-table-column>
        </el-table>
    </div>
        data() {
            return {
                tableData: [{"name": "张三", "gender": "男"}, {"name": "李四", "gender": "女"}]
            }
        },
        methods: {
            exportToExcel() {
                require.ensure([], () => {
                    const {export_json_to_excel} = require("@/plugins/Export2Excel");
                    // 导出后excel的表头
                    const tHeader = [
                        "姓名",
                        "性别"
                    ];
                    // 源数据对应的属性名
                    const filterVal = [
                        "name",
                        "gender"
                    ];
                    // 获取源数据
                    const list = this.tableData;
                    const data = this.formatJson(filterVal, list);
                    export_json_to_excel(tHeader, data, "导出后的文件名");
                });
            },
            formatJson(filterVal, jsonData) {
                return jsonData.map(v => filterVal.map(j => v[j]));
            },
        }

读取本地Excel

  1. 将本地的Excel拷贝到项目的public文件夹中
    比如Excel文件相对于index.html文件的相对路径为 “./Excels/极度认真系统.xlsx”
  2. 安装插件
npm install xlsx
  1. 安装axios
npm install axios --save-dev

在 src/main.js 中导入 axios

import axios from 'axios'
Vue.prototype.$http = axios
  1. vue页面中
import XLSX from 'xlsx'
 
created() {
    // Excel文件相对于index.html文件的相对路径
    let url = "./Excels/极度认真系统.xlsx"
    this.$http.get(url, {responseType: 'arraybuffer'})
        .then((res) => {
            let data = new Uint8Array(res.data)
            let wb = XLSX.read(data, {type: "array"})
            // ‘2020年日记’ 为Excel文件中的表名
            let content = wb.Sheets['2020年日记']
            this.data = XLSX.utils.sheet_to_json(content)
        })
},

假设本地表格中的内容为:

姓名 性别
张三
李四

则此时 data中中的数据为

data:[
    {
        "姓名":'张三',  "性别":'男',
    },
    {
        "姓名":'李四',  "性别":'女',
    },
],

json转Excel

原理与导出下载Excel相同

  1. 下载引入Blob.js和 Export2Excel.js
    https://pan.baidu.com/share/init?surl=Qa6Quk-dJLuYSuskK_piiw
    提取码:dy8m

将下载的Blob.js和 Export2Excel.js文件放在src/plugins文件夹中

  1. 安装插件
npm install -D script-loader
npm install -S file-saver
  1. json转Excel的函数
            JSONtoExcel(JSONdata) {
                require.ensure([], () => {
                    const {export_json_to_excel} = require("@/plugins/Export2Excel");

                    // 将源数据转化为对象
                    let list = JSON.parse(JSONdata)

                    let keyList =[]

                    for (let key in list[0]) {
                        keyList.push(key)
                    }

                    // 导出后excel的表头
                    const tHeader = keyList

                    // 源数据对应的属性名
                    const filterVal = keyList

                    const data = this.formatJson(filterVal, list);
                    export_json_to_excel(tHeader, data, "导出后的文件名");
                });
            },

[
{"name": "张三", "gender": "男"},
{"name": "李四", "gender": "女"}
]
目录
相关文章
|
10月前
|
存储 Java easyexcel
招行面试:100万级别数据的Excel,如何秒级导入到数据库?
本文由40岁老架构师尼恩撰写,分享了应对招商银行Java后端面试绝命12题的经验。文章详细介绍了如何通过系统化准备,在面试中展示强大的技术实力。针对百万级数据的Excel导入难题,尼恩推荐使用阿里巴巴开源的EasyExcel框架,并结合高性能分片读取、Disruptor队列缓冲和高并发批量写入的架构方案,实现高效的数据处理。此外,文章还提供了完整的代码示例和配置说明,帮助读者快速掌握相关技能。建议读者参考《尼恩Java面试宝典PDF》进行系统化刷题,提升面试竞争力。关注公众号【技术自由圈】可获取更多技术资源和指导。
|
11月前
|
前端开发
实现Excel文件和其他文件导出为压缩包,并导入
实现Excel文件和其他文件导出为压缩包,并导入
212 1
|
SQL C# 数据库
EPPlus库的安装和使用 C# 中 Excel的导入和导出
本文介绍了如何使用EPPlus库在C#中实现Excel的导入和导出功能。首先,通过NuGet包管理器安装EPPlus库,然后提供了将DataGridView数据导出到Excel的步骤和代码示例,包括将DataGridView转换为DataTable和使用EPPlus将DataTable导出为Excel文件。接着,介绍了如何将Excel数据导入到数据库中,包括读取Excel文件、解析数据、执行SQL插入操作。
EPPlus库的安装和使用 C# 中 Excel的导入和导出
|
12月前
|
JavaScript 前端开发 数据处理
Vue导出el-table表格为Excel文件的两种方式
Vue导出el-table表格为Excel文件的两种方式
726 6
|
JSON JavaScript 数据格式
vue写入json数据到文本中+vue引入cdn的用法
vue写入json数据到文本中+vue引入cdn的用法
142 10
|
前端开发 JavaScript
使用Vue+xlsx+xlsx-style实现导出自定义样式的Excel文件
本文介绍了在Vue项目中使用`xlsx`和`xlsx-style`(或`xlsx-style-vite`)库实现导出具有自定义样式的Excel文件的方法,并提供了详细的示例代码和操作效果截图。
2172 2
使用Vue+xlsx+xlsx-style实现导出自定义样式的Excel文件
|
JSON 前端开发 JavaScript
java中post请求调用下载文件接口浏览器未弹窗而是返回一堆json,为啥
客户端调接口需要返回另存为弹窗,下载文件,但是遇到的问题是接口调用成功且不报错,浏览器F12查看居然返回一堆json,而没有另存为弹窗; > 正确的效果应该是:接口调用成功且浏览器F12不返回任何json,而是弹窗另存为窗口,直接保存文件即可。
461 2
|
前端开发 JavaScript Java
导出excel的两个方式:前端vue+XLSX 导出excel,vue+后端POI 导出excel,并进行分析、比较
这篇文章介绍了使用前端Vue框架结合XLSX库和后端结合Apache POI库导出Excel文件的两种方法,并对比分析了它们的优缺点。
2662 0
|
JavaScript 前端开发 easyexcel
基于SpringBoot + EasyExcel + Vue + Blob实现导出Excel文件的前后端完整过程
本文展示了基于SpringBoot + EasyExcel + Vue + Blob实现导出Excel文件的完整过程,包括后端使用EasyExcel生成Excel文件流,前端通过Blob对象接收并触发下载的操作步骤和代码示例。
2353 0
基于SpringBoot + EasyExcel + Vue + Blob实现导出Excel文件的前后端完整过程
|
关系型数据库 MySQL Windows
MySQL数据导入:MySQL 导入 Excel 文件.md
MySQL数据导入:MySQL 导入 Excel 文件.md