一尘不染

Excel 到 JSON javascript 代码?

javascript

我想将 excel 工作表数据转换为 json。它必须是动态的,因此有一个上传按钮,用户可以在其中上传 excel 表格,然后将数据转换为 json。你能提供我的javascript代码吗?我尝试了 SheetJS 但无法弄清楚。我更喜欢直截了当的东西:)

我真的很感谢你的帮助!


阅读 93

收藏
2022-08-29

共1个答案

一尘不染

注意:不是 100% 跨浏览器

检查浏览器兼容性@ http://caniuse.com/#search=FileReader

正如您将看到的那样,人们对不太常见的浏览器有问题,但这可能归结为浏览器的版本。我总是建议使用caniuse之类的东西来查看支持哪一代浏览器…这只是一个为用户工作的答案,而不是供人们使用的最终复制和粘贴代码..

小提琴:http: //jsfiddle.net/d2atnbrt/3/

HTML代码:

<input type="file" id="my_file_input" />
<div id='my_file_output'></div>

JS代码:

var oFileIn;

$(function() {
    oFileIn = document.getElementById('my_file_input');
    if(oFileIn.addEventListener) {
        oFileIn.addEventListener('change', filePicked, false);
    }
});


function filePicked(oEvent) {
    // Get The File From The Input
    var oFile = oEvent.target.files[0];
    var sFilename = oFile.name;
    // Create A File Reader HTML5
    var reader = new FileReader();

    // Ready The Event For When A File Gets Selected
    reader.onload = function(e) {
        var data = e.target.result;
        var cfb = XLS.CFB.read(data, {type: 'binary'});
        var wb = XLS.parse_xlscfb(cfb);
        // Loop Over Each Sheet
        wb.SheetNames.forEach(function(sheetName) {
            // Obtain The Current Row As CSV
            var sCSV = XLS.utils.make_csv(wb.Sheets[sheetName]);   
            var oJS = XLS.utils.sheet_to_row_object_array(wb.Sheets[sheetName]);   

            $("#my_file_output").html(sCSV);
            console.log(oJS)
        });
    };

    // Tell JS To Start Reading The File.. You could delay this if desired
    reader.readAsBinaryString(oFile);
}

这也需要https://cdnjs.cloudflare.com/ajax/libs/xls/0.7.4-a/xls.js转换为可读格式,我还使用 jquery 仅用于更改 div 内容和dom 就绪事件.. 所以不需要 jquery

这是我能得到的最基本的,

编辑 - 生成表格

小提琴:http: //jsfiddle.net/d2atnbrt/5/

第二个小提琴显示了一个生成您自己的表的示例,这里的关键是使用 sheet_to_json 以正确格式获取数据以供 JS 使用..

第二个小提琴中的一个或两个评论可能不正确,因为第一个小提琴的修改版本.. CSV 评论至少是

测试 XLS 文件: http: //www.whitehouse.gov/sites/default/files/omb/budget/fy2014/assets/receipts.xls

这不包括 XLSX 文件,使用他们的示例应该很容易调整它们。

2022-08-29