增强版 JavaScript 读取 Excel

功能:限制只能选 Excel、解析表头、过滤空行、返回干净数组、错误提示,直接复制就能用。

html

预览

复制代码
<input type="file" id="fileInput" accept=".xlsx,.xls" />
<script src="https://cdn.jsdelivr.net/npm/xlsx@0.18.5/dist/xlsx.full.min.js"></script>

<script>
const fileInput = document.getElementById('fileInput');

fileInput.addEventListener('change', async function (e) {
    const file = e.target.files[0];
    if (!file) return;

    // 1. 校验文件格式
    const suffix = file.name.slice(-5).toLowerCase();
    if (!suffix.includes('.xlsx') && !suffix.includes('.xls')) {
        alert('请上传 xlsx 或 xls 格式的Excel文件');
        fileInput.value = '';
        return;
    }

    // 2. 读取文件
    const reader = new FileReader();
    reader.readAsArrayBuffer(file);

    reader.onload = function (ev) {
        try {
            // 解析Excel
            const data = new Uint8Array(ev.target.result);
            const workbook = XLSX.read(data, { type: 'array' });
            
            // 获取第一个工作表
            const firstSheet = workbook.SheetNames[0];
            const sheet = workbook.Sheets[firstSheet];

            // 3. 转JSON并自动识别表头
            let list = XLSX.utils.sheet_to_json(sheet, {
                header: 1   // 第一行作为表头
            });

            // 4. 过滤空行、空数据
            list = filterEmptyRow(list);

            console.log('解析后Excel数据:', list);
            // 在这里可以渲染表格、传给后端等
        } catch (err) {
            alert('文件解析失败,请检查Excel格式');
            console.error(err);
        }
    }

    reader.onerror = function () {
        alert('文件读取失败');
    }
});

// 过滤空行工具方法
function filterEmptyRow(arr) {
    return arr.filter(row => {
        // 去掉整行都是空的
        return row.some(item => item !== undefined && item !== '');
    });
}
</script>

增强功能亮点

  1. 限制只能上传 .xlsx/.xls,拦截其他文件
  2. 异常捕获,解析失败有弹窗提示
  3. 自动以第一行为表头解析
  4. 自动过滤空白行、无效空数据
  5. 兼容所有现代浏览器,无需后端

拿到的数据格式示例

js

复制代码
[
  ["姓名","年龄","性别"],
  ["张三",20,"男"],
  ["李四",22,"女"]
]
相关推荐
吃好睡好便好1 小时前
在Matlab中绘制马鞍函数曲面图
开发语言·人工智能·学习·算法·matlab·信息可视化
tedcloud1231 小时前
OfficeCLI部署教程:让AI直接操作Word、Excel和PPT
服务器·人工智能·word·excel
测试员周周1 小时前
【Appium 系列】第01节-Appium 是什么 — 移动端自动化的行业标准
开发语言·人工智能·python·功能测试·appium·自动化·测试用例
码界筑梦坊1 小时前
117-基于Python的印度犯罪数据可视化分析系统
开发语言·python·mysql·信息可视化·毕业设计·echarts·fastapi
Wy_编程1 小时前
golang 基础语法和函数
开发语言·go
城数派1 小时前
1958-2024年全球4km分辨率逐月土壤湿度栅格数据
数据库·arcgis·信息可视化·excel
渡我白衣1 小时前
定时器与时间轮思想
linux·开发语言·前端·c++·人工智能·深度学习·神经网络
luyun0202021 小时前
实用小工具,吾爱出品
开发语言·c++·算法
Highcharts.js1 小时前
Highcharts React v5版本迁移的核心注意事项和步骤清单
开发语言·javascript·react.js·前端框架·highcharts