JSON是碼農們經常使用的數據格式,輕且方便,而直接手敲JSON倒是比較麻煩和使人心情崩潰的(由於重複的東西不少),因此不少碼農可能會和我同樣,選擇用Excel去輸入數據,而後再想辦法轉換成JSON格式。今天教你們使用JS 將 Excel 轉爲 JSON的方法。javascript
<html lang="en">
<title> Convert Excel File To JSON </title>
<head>
<script>
</script>
</head>
<body>
</body>
複製代碼
咱們能夠使用<input>標籤接收上傳文件。代碼以下:html
<input type="file" id="fileUploader" name="fileUploader" accept=".xls, .xlsx"/>
複製代碼
<script>
$(document).ready(function(){
$("#fileUploader").change(function(evt){
// 上傳文件處理邏輯...
});
});
</script>
複製代碼
在這裏,咱們假設用戶只上傳一個文件。java
var selectedFile = evt.target.files[0];
複製代碼
接下來,咱們將使用FileReader讀取該文件數據。從這個FileReader,咱們能夠讀取excel文件中的數據做爲二進制字符串。而後咱們使用XLSX,它是SheetJS js-xlsx的內置工具,將咱們的二進制字符串轉換爲JSON對象。引入 XLSXjquery
<script lang =「javascript」src =「dist/xlsx.full.min.js」> </ script>
複製代碼
您能夠下載源碼xlsx.full.min.jsgit
完整代碼github
<html lang="en">
<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表格。 json
讀出json數據以下bash
大功告成!!!工具
SheetJS 還有不少實用的功能,具體更多功能請自行去github查看githu地址ui
演示源碼地址code