js读取Excel数据

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
   <title>读取Excel</title>	
   <script
  src="https://code.jquery.com/jquery-2.2.4.js"
  integrity="sha256-iT6Q9iMJYuQiMWNd9lDyBUStIq/8PuOW33aOqmvFpqI="
  crossorigin="anonymous"></script>
   <script src="https://cdn.bootcss.com/xlsx/0.15.1/xlsx.core.min.js"></script>
</head>
<body>
<br/>
<label for="excel-file" class="btn btn-success">导入Excel文件</label>
<input type="file" name="excel-file" id="excel-file"/>
<br>
<table id="context">
 
</table>
 
  <script>  
	$('#excel-file').change(function(e) {            
	        try {
	            new Uint8Array([1,2]).slice(0,2);
	        } catch (e) {
	            console.log("[Uint8Array"+e.description+"]这里使用【Array.slice】。");
	            //IE或有些浏览器不支持Uint8Array.slice()方法。改成使用Array.slice()方法
	            Uint8Array.prototype.slice = Array.prototype.slice;
	        }
	        var url=$('#excel-file').val();
	        if(!url){return;}
	        var suffix=url.substring(url.lastIndexOf(".")+1,url.length);
	        if(!(suffix=="xls"||suffix=="xlsx")){
	            return alert("文件类型不正确");
	        }
	        var files = e.target.files;	        
	        var fileReader = new FileReader();
	        fileReader.readAsArrayBuffer(files[0]);// 以二进制方式打开文件
	        fileReader.onload = function(ev) {
	            $('#excel-file').val('');
	            $("#context").html("");
	            try {	                
	            	var data = ev.target.result;
	            	var workbook = XLSX.read(data, { type: 'array'}),
	                persons = [];
	            } catch (e) {
	            	console.error(e);
	                return alert('文件类型不正确!');
	            }
	            
	            //遍历每张表读取
	            for (var sheet in workbook.Sheets) {
	                if (workbook.Sheets.hasOwnProperty(sheet)) {
	                    persons = persons.concat(XLSX.utils.sheet_to_json(workbook.Sheets[sheet],{raw:true, header:1}));
	                    
	                    for ( var i = 0; i <persons.length; i++){
	                        var person=persons[i];
	                        var tr='<tr id="tr-'+i+'">';
	                        for (var j = 0; j <person.length; j++){
	                            tr+='<td>'+$.trim(person[j]?person[j]:"")+'</td>';
	                        }
	                        for (var k = 0; k < (6-person.length); k++) {
	                        	tr+='<td></td>';
							}
	                        if(person.length>1){
	                            tr+='<td style="padding:6px;"><a href="javascript:$(\'#tr-'+i+'\').remove();" class="btn btn-danger btn-xs">删除</a></td></tr>';
	                            $("#context").append(tr);
	                        }
	                    }
	                    //break;// 如果只取第一张表,就把beak注释取消
	                }
	            }
				console.log(persons)
	        };
	    });
 
  </script>
</body>
</html>

 

JavaScript可以使用一些库和工具来读取Excel表格数据。其中最常用的是使用`SheetJS`库,它可以帮助我们读取和处理Excel文件。 首先,我们需要引入`SheetJS`库。可以通过在HTML文件中添加以下代码来引入这个库: ``` <script src="https://unpkg.com/xlsx/dist/xlsx.full.min.js"></script> ``` 接下来,我们可以编写JavaScript代码来读取Excel表格数据。首先,我们需要选择并上传一个Excel文件: ```javascript var fileInput = document.getElementById('fileInput'); var workbook; fileInput.addEventListener('change', function(e) { var file = e.target.files[0]; var reader = new FileReader(); reader.onload = function(e) { var data = new Uint8Array(e.target.result); workbook = XLSX.read(data, { type: 'array' }); }; reader.readAsArrayBuffer(file); }); ``` 上述代码将会在文件选择框的`change`事件发生时触发。一旦读取完成,我们将获取到一个`workbook`对象,它包含了Excel文件的所有信息。 然后,我们可以使用`SheetJS`库提供的API来读取具体的单元格数据。可以通过以下代码来读取第一个Sheet的A1单元格的数据: ```javascript var worksheet = workbook.Sheets[workbook.SheetNames[0]]; var cellValue = worksheet.A1.v; ``` 通过上述代码,我们可以读取Excel表格中各个单元格的数据。可以根据需要进行循环遍历和处理。 需要注意的是,由于安全性的限制,JavaScript无法直接访问本地计算机文件系统上的文件,因此需要用户手动选择并上传文件。同时,由于使用了第三方库,需要保证可以访问到这些库的链接。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值