【js】將excel 轉化為json格式


 

 

 使用JavaScript將Excel轉換為JSON

JSON是碼農們常用的數據格式,輕且方便,而直接手敲JSON卻是比較麻煩和令人心情崩潰的(因為重復的東西很多),所以很多碼農可能會和我一樣,選擇用Excel去輸入數據,然后再想辦法轉換成JSON格式。今天教大家使用JS 將 Excel 轉為 JSON的方法。

1.新建HTML文件

<html lang="en">    
<title> Convert Excel File To JSON </title>
<head>
    <script>
    </script>
</head>
<body>
</body>

 

我們可以使用<input>標簽接收上傳文件。代碼如下:

 <input type="file" id="fileUploader" name="fileUploader" accept=".xls, .xlsx"/>

2.監聽input change 事件

<script>
    $(document).ready(function(){
        $("#fileUploader").change(function(evt){
            // 上傳文件處理邏輯...
        });
    });
</script>

3.讀取上傳文件

在這里,我們假設用戶只上傳一個文件。

var selectedFile = evt.target.files[0];

接下來,我們將使用FileReader讀取該文件數據。

從這個FileReader,我們可以讀取excel文件中的數據作為二進制字符串。

然后我們使用XLSX,它是SheetJS js-xlsx的內置工具,將我們的二進制字符串轉換為JSON對象。

引入 XLSX

<script lang =“javascript”src =“dist/xlsx.full.min.js”> </ script>

 

完整代碼

<html>    

<title> Convert Excel File To JSON </title>

<head>
    <script src="js/jquery.js"> </script>
    <script lang="javascript" src="js/xlsx.full.min.js"></script>
    <script>
        $(document).ready(function(){
            $("#fileUploader").change(function(evt){
                    var selectedFile = evt.target.files[0];
                    var reader = new FileReader();
                    reader.onload = function(event) {
                        var data = event.target.result;
                        var workbook = XLSX.read(data, {
                            type: 'binary'
                        });
                        workbook.SheetNames.forEach(function(sheetName) {
                            var XL_row_object = XLSX.utils.sheet_to_row_object_array(workbook.Sheets[sheetName]);
                            if (XL_row_object.length > 0) {
                                document.getElementById("jsonObject").innerHTML = JSON.stringify(XL_row_object);
                            }
                          
                        })
                    };
                    reader.onerror = function(event) {
                    console.error("File could not be read! Code " + event.target.error.code);
                };
                // 讀取上傳文件為二進制
                reader.readAsBinaryString(selectedFile);
            });
        });
    </script>
</head>
<body>
    <input type="file" id="fileUploader" name="fileUploader" accept=".xls, .xlsx"/>
    </br></br>
    JSON : <label id="jsonObject"> </label>
</body>
 

作為示例,我們使用如下的excel表格。

excel

讀出json數據如下

 

 

 相關資料:


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM