使用sheetjs读取excle表格

	//cdn引入js
	<script lang="javascript" src="https://cdn.sheetjs.com/xlsx-latest/package/dist/xlsx.full.min.js"></script>
	
	var url = "http://127.0.0.1:8848/dome/file/excle1.xlsx";
	/* set up async GET request */
	var req = new XMLHttpRequest();
	req.open("GET", url, true);  //读取表格文件  如果是input选取文件那直接把文件流传入  XLSX.read(文件流); 就可以了
	req.responseType = "arraybuffer";
	req.onload = function(e) {
	  	var workbook = XLSX.read(req.response);
		console.log(workbook.Sheets)  //多个表的名称 表一 表二
		list = XLSX.utils.sheet_to_json(workbook.Sheets[workbook.SheetNames[0]])  //拿到表一的数据并转换格式
		console.log(list)  //looklook
	};
<!-- 完整案例,替换url就可使用 -->
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<!-- use the latest version -->
		<script lang="javascript" src="https://cdn.sheetjs.com/xlsx-latest/package/dist/xlsx.full.min.js"></script>
		
	</head>
	<style type="text/css">
		.prize_list{width: 90%;max-width: 960px;height: 70vh;position: fixed;top: 50%;left: 50%;transform: translate(-50%,-50%);
		box-shadow: 0 0 5px #333;border-radius: 10px;overflow-y: auto;display: block;}
		.prize_list .item{margin-top: 10px;	text-align: center;display: flex; justify-content: space-around;}
		.prize_list .item .box{flex-shrink: 0;flex: 1;}
	</style>
	<body>
		<table class="prize_list">
			<tr class="prize_item">
			</tr>
		</table>
	</body>
	<script>
	
	var url = "http://127.0.0.1:8848/dome/file/excle1.xlsx";
	let list = ''

	/* set up async GET request */
	var req = new XMLHttpRequest();
	req.open("GET", url, true);
	req.responseType = "arraybuffer";
	req.onload = function(e) {
	  var workbook = XLSX.read(req.response);
		console.log(workbook.Sheets)
		list = XLSX.utils.sheet_to_json(workbook.Sheets[workbook.SheetNames[0]])
		let list_dom = document.querySelector('.prize_list')
		list_dom.innerHTML = ''
		list_dom.appendChild(addTH((list[0])))
		list.map(res=>{
			list_dom.appendChild(addTD(res))
		})
	};
	
	req.send();
	
	function addTH(data){
		let item = document.createElement('tr')
		item.className = 'item'
		for(let sheet in data){
			if(sheet !== '收件地址'){ //跳过某些不显示的字段
			item.innerHTML +=  `<th class="box">${sheet}</th>`	
			}
			
		}
		return item
	}
	function addTD(data){
		let item = document.createElement('tr')
		item.className = 'item'
		for(let sheet in data){
			if(sheet !== '收件地址'){  //跳过某些不显示的字段
				if(sheet === '联系电话'){
					let req = /(\d{3})\d{4}(\d{4})/;  //替换中间四位
					data[sheet] = data[sheet].toString().replace(req,"$1****$2")
				}
				item.innerHTML +=  `<td class="box">${data[sheet]}</td>`
			}
		}
		return item
	}
	
	</script>
</html>

案例效果
展示效果

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
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无法直接访问本地计算机文件系统上的文件,因此需要用户手动选择并上传文件。同时,由于使用了第三方库,需要保证可以访问到这些库的链接。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值