【前端】读取 xlsx 文件并转化成 json 数据

1、使用 XMLHttpRequest

html 复制代码
<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8" />
        <title>Read Excel with JavaScript</title>
    </head>
    <body>
        <script src="https://cdnjs.cloudflare.com/ajax/libs/xlsx/0.17.5/xlsx.full.min.js"></script>
        <script>
            // 创建 XMLHttpRequest
            var xhr = new XMLHttpRequest();

            // 配置请求类型和URL
            xhr.open("GET", "./测试.xlsx", true);
            xhr.responseType = "arraybuffer"; // 重要:设置响应类型为arraybuffer以接收二进制数据

            // 处理请求状态改变
            xhr.onreadystatechange = function () {
                if (xhr.readyState === 4 && xhr.status === 200) {
                    // 当请求成功完成
                    var data = new Uint8Array(xhr.response); // 获取返回的二进制数据

                    // 使用SheetJS解析二进制数据
                    var workbook = XLSX.read(data, { type: "array" });

                    // 读取第一个工作表
                    var firstSheetName = workbook.SheetNames[0];
                    var worksheet = workbook.Sheets[firstSheetName];

                    // 将工作表转换为JSON
                    var jsonData = XLSX.utils.sheet_to_json(worksheet);

                    // 处理JSON数据
                    console.log(jsonData);
                }
            };

            // 发送请求
            xhr.send();
        </script>
    </body>
</html>

2、使用 input

html 复制代码
<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8" />
        <title>Read Excel with JavaScript</title>
    </head>
    <body>
        <input type="file" id="fileInput" />
        <pre id="output"></pre>

        <script src="https://cdnjs.cloudflare.com/ajax/libs/xlsx/0.17.5/xlsx.full.min.js"></script>
        <script>
            // JavaScript 部分在这里
            document
                .getElementById("fileInput")
                .addEventListener("change", handleFile, false);

            function handleFile(event) {
                const file = event.target.files[0];
                const reader = new FileReader();

                reader.onload = function (e) {
                    const data = new Uint8Array(e.target.result);
                    const workbook = XLSX.read(data, { type: "array" });

                    // 获取第一个工作表的名称
                    const firstSheetName = workbook.SheetNames[0];
                    // 获取第一个工作表
                    const worksheet = workbook.Sheets[firstSheetName];

                    // 将工作表内容转换为 JSON 格式
                    const jsonData = XLSX.utils.sheet_to_json(worksheet, {
                        header: 1,
                    });

                    console.log(jsonData);

                };

                reader.readAsArrayBuffer(file);
            }
        </script>
    </body>
</html>
相关推荐
\xin3 小时前
pikachu自编exp,xss反射性get,post,存储型xss,dom,dom-x
前端·javascript·xss
是烟花哈7 小时前
【前端】React框架学习
前端·学习·react.js
qq4356947018 小时前
JavaWeb08
前端
2401_878454539 小时前
html和css的复习(1)
前端·css·html
@PHARAOH9 小时前
WHAT - git worktree 概念
前端·git
IT_陈寒10 小时前
我竟然被JavaScript的隐式类型转换坑了三天!
前端·人工智能·后端
我亚索贼六丶10 小时前
二十六. AI基础概念之如何更好的使用AI
前端
小码哥_常10 小时前
安卓启动页Logo适配秘籍:告别“奇形怪状”的展示
前端
我亚索贼六丶10 小时前
二十五.Electron 初体验与进阶
前端
当时只道寻常10 小时前
像使用 Redis 一样操作 LocalStorage
前端·前端工程化