使用这个js库:https://github.com/SheetJS/sheetjs
中文文档在:https://github.com/rockboom/SheetJS-docs-zh-CN
下载dist中的xlsx.core.min.js
即可满足使用
xlsx.core.min.js
一个比较好的教程博客:https://www.cnblogs.com/liuxianan/p/js-excel.html
示例
<html>
<head>
<script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.js"></script>
<script src="./xlsx.core.min.js"></script>
</head>
<body>
<input type="file" id="excel-file">
<textarea id="area" cols="30" rows="10"></textarea>
<script>
$('#excel-file').change(function (e) {
var files = e.target.files;
var fileReader = new FileReader();
fileReader.onload = function (ev) {
try {
var data = ev.target.result
var workbook = XLSX.read(data, {
type: 'binary'
}) // 以二进制流方式读取得到整份excel表格对象
} catch (e) {
console.log('文件类型不正确');
return;
}
//在控制台打印出来表格中的数据
console.log(workbook);
var sheet1 =workbook.Sheets[ workbook.SheetNames[0] ]
console.log(XLSX.utils.sheet_to_json(sheet1,{range:1}))
$("#area").val(JSON.stringify(XLSX.utils.sheet_to_json(sheet1,{range:1})));
};
// 以二进制方式打开文件
fileReader.readAsBinaryString(files[0]);
});
</script>
</body>
</html>
XLSX.utils.sheet_to_json
函数可以将sheet输出为json对象。
range可以指定sheet的范围,数字就是起始行,0表示从第一行开始输出,1从第二行开始。
我写的XLSX.utils.sheet_to_json(sheet1,{range:1})
就是从第二行开始输出。输出结果就是对象数组: