当前位置: 首页 > news >正文

javascript导入excel文件

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

<!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 按钮可以方便的调节按钮的样式。

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');
}   

        文件信息。

        页面上取值。

相关文章:

  • 如何搭建一台永久运行的个人服务器?
  • 模型训练——使用预训练权重、冻结训练
  • Dante Cloud 是国内首个支持阻塞式和响应式融合的微服务
  • 设计模式之访问者模式
  • Apache安装教程
  • ArcGIS中几个好用的空间分析工具
  • 【ARM64 常见汇编指令学习 19.3 -- ARMv8 三目运算指令 csel 详细介绍】
  • C++STL---stack queue模拟实现
  • 微信小程序实现图片转base64
  • idea中使用maven-helper插件阅读排查【经典版】2
  • Alsa UCM
  • git【工具软件】分布式版本控制工具软件
  • 链表的回文结构OJ
  • CSS实现一个雨滴滑落效果
  • 【第二节】C/C++数据结构之线性表
  • 【linux】自定义快捷命令/脚本
  • 【机器学习】训练GNN图神经网络模型进行节点分类
  • WindowManager相关容器类
  • 【自定义View】Android圆饼进度条
  • 循环嵌套语句的实际应用(2)
  • 上海畅通“外转内”,外贸优品成“香饽饽”
  • 禅定佛的微笑,从樊锦诗提到过的那尊说起
  • 当Z世代与传统戏曲在春日校园相遇
  • 包揽金银!王宗源、郑九源夺得跳水世界杯总决赛男子3米板冠亚军
  • 巴菲特执掌60年,伯克希尔市值如何增长5.5万倍?详解五大经典投资案例
  • 空间方法:一周城市生活