javascript导入excel文件

导入文件用到一个 xlsx.core.js 的包。

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <script type="text/javascript" src="./xlsx.core.min.js"></script>
    <title>Document</title>
</head>

<body>
    <input type="file" id="file" style="display:none;" />
    <button onclick="importFile()">导入</button>
</body>
<script type="text/javascript" src="./index.js"></script>
</html>

隐藏 input 框,加一个 button 按钮可以方便的调节按钮的样式。

javascript 复制代码
function importFile() {
    console.log('导入');
    document.getElementById('file').click();
}

document.getElementById('file').addEventListener('change', function (e) {
    let files = e.target.files;
    if (files.length == 0) return;
    let f = files[0];

    if (!/\.xlsx$/g.test(f.name)) {
        alert('仅支持读取xlsx格式!');
        return;
    }
    e.target.value = "" // 清空上一次上传的数据,防止第二次无法上传
    readWorkbookFromLocalFile(f, function (workbook) {
        readWorkbook(workbook);
    });
});

function readWorkbookFromLocalFile(file, callback) {
    let reader = new FileReader();
    reader.onload = function (e) {
        let data = e.target.result;
        let workbook = XLSX.read(data, { type: 'binary' });
        if (callback) callback(workbook);
    };
    reader.readAsBinaryString(file);
}

function readWorkbook(workbook) {
    let sheetNames = workbook.SheetNames; // 工作表名称集合
    console.log(sheetNames, 'sheetNames');
    let worksheet = workbook.Sheets[sheetNames[0]]; // 读取第一张sheet
    console.log(worksheet, 'worksheet');
    let json = XLSX.utils.sheet_to_json(worksheet);
    // let json = XLSX.utils.sheet_to_json(worksheet, { range: 1 }) // range: 1 可以设置是从第几行开始读,不设置从第一行开始读
    console.log(json, 'json');
}   

文件信息。

页面上取值。

相关推荐
走粥1 分钟前
使用indexOf查找对象结合Pinia持久化引发的问题
开发语言·前端·javascript
北寻北爱11 分钟前
前端加密解密- base64、md5、sha256、AES
前端·vue.js
柒.梧.12 分钟前
Redis通用命令+五大核心数据结构
前端·bootstrap·html
Refly22 分钟前
【微信接入 OpenClaw 龙虾🦞】10分钟手把手教程完成接入,Claude 模型无限使用
前端·微信·github
恋猫de小郭29 分钟前
为什么中转渠道的顶级模型会不好用?这是一个技术问题
前端·人工智能·ai编程
发现一只大呆瓜34 分钟前
React-深度拆解 React路由:从实战进阶到底层原理
前端·react.js·面试
不甜情歌35 分钟前
搞懂 Promise:告别回调嵌套,再也不怕异步代码乱成麻
前端·javascript
野草arthas37 分钟前
什么是视觉层次?为什么需要它?
前端
发现一只大呆瓜1 小时前
React-手把手带你实现 Keep-Alive 效果
前端·react.js·面试
酉鬼女又兒1 小时前
入门前端CSS 媒体查询全解析:从入门到精通,打造完美响应式布局(可用于备赛蓝桥杯Web应用开发)
前端·css·职场和发展·蓝桥杯·前端框架·html5·媒体