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