1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > js-xlsx 读取Excel解析

js-xlsx 读取Excel解析

时间:2023-11-30 03:58:08

相关推荐

js-xlsx 读取Excel解析

近期公司开始做绩效,某一天上午 HR 妹纸发了份 Excel 模板过来,让我下发给小组内成员填写。当天下午下班前,组内的绩效表就收齐了,接下来我就开始进入下一个环节,逐一打开每个 Excel 表为每个人打分。由于只有十几份绩效表,所以很快就打完分了。

不过问题来了,虽然已经打完分了,但我对小组内成员的每个考核项得分和总分的情况却还是一片空白。想要一目了然,当然得简单做个统计报表咯。那么如何收集每个人的数据呢?当然最简单的方式就一个个打开组内成员的绩效表,然后一个个统计,不过对于这种方式,我是拒绝的。作为一个小小的程序猿,还是得施展一下雕虫小技 —— “自动提取数据”。

现在基于目前的需求,我们来梳理一下流程:

读取某个目录下绩效文件列表;读取某个绩效文件;解析文件并提取相关信息;保存每份文件的数据并输出。

既然流程已基本清楚,下面就要撸起柚子加油干咯,工具当然就是选用我们前端的神器 —— Node.js,嘿嘿,不然就挂羊头卖狗肉了(Node.js 小打小闹系列)。

在上面流程中,Excel 解析是核心的步骤,因此我们先来完成 “选酷” 环节。经过一番筛选,我们最终选定了js-xlsx这个库。

js-xlsx 简介

在介绍这个库之前,我们先来介绍 Excel 的一些相关概念。

workbook 对象:整个 Excel 文档,使用 js-xlsx 读取 Excel 文档之后就会获得 workbook 对象。worksheet 对象:Excel 文档中的表,一份 Excel 文档中可以包含很多表,而每张表对应的就是 worksheet 对象。cell 对象:worksheet 中的单元格,一个单元格就是一个 cell 对象。

它们之间的关系如下:

了解完 Excel 的基本概念,我们来继续介绍一下js-xlsx这个库的基本用法:

使用XLSX.readFile()读取 Excel 文件通过workbook.Sheets[SHEET_NAME]获取 SHEET_NAME 对应的表名按需进行数据读取和处理

此外通过查看文档,我们发现XLSX.utils为我们提供了一系列有用的工具方法,比如:

XLSX.utils.sheet_to_csv —— 生成 CSV 文件。XLSX.utils.sheet_to_txt —— 生成 UTF16 格式的文本。XLSX.utils.sheet_to_html —— 生成 HTML 文件。XLSX.utils.sheet_to_json —— 生成 JSON 格式的数组对象。

当看到XLSX.utils.sheet_to_json这个函数时,感觉 Excel 解析的事情都完成一半了。时机已经成熟了,现在我们马上进入实战环节。

js-xlsx 实战

在开始动手前,我们先来看分析一下 Excel 绩效表,具体如下图所示:

图中,红色框用于表示 Excel 表名,青色框用于表示需要提取的数据区域,需要提取的内容,主要有:姓名、考核月份、常规工作得分、重点工作得分、工作态度与能力得分及总得分等。

通过上面的代码,我们就能把 “员工绩效” 表单转换为 JSON 对象,输出的结果如下:

通过观察以上的输出信息,我们发现了数据的共同特点,比如:

因此要想提取相应的信息,我们可以定义以下正则表达式:

基于上面的表达式,我们可以抽取一个通用的函数来解析 Excel Sheet 表中的数据:

运行 parseSheetData 函数后,将会输出以下信息:

获取完每个 Excel 表的信息后,我们再来为每一个项定义一个对应的键:

接下来我们可以利用lodash的zipObject()方法生成相应的对象:

此时,我们已经知道如何解析单个 Excel 文件,后面我们要做的事情就是获取某个目录下的所有绩效表,然后逐个进行解析,然后把解析的数据保存到数组中,最终我们就能获取团队成员整个月份的绩效数据了。

数据已经收集完成了,那下一步要做什么呢?嘿嘿,那还用说,当然是做数据展示了,其实还有一个更加高大尚的名字 —— 数据可视化。目前数据可视化,也是一个比较热门的领域,涉及的知识也很多。对于感兴趣的同学,推荐了解一下阿里巴巴的墨者学院—— “成就更多数据可视化领域中的「墨者」”。

最后我还简单设计了一个报表页,期间用到了以下几个库,感兴趣的同学可以了解一下:

antvis/f2—— F2 移动端可视化解决方案odometer—— 实现平滑的数字动画效果canvas-nest.js—— 一个基于 html5 canvas 绘制的网页背景效果,非常赞!

Excel 解析器

Excel 绩效表的解析器实现如下,有兴趣的同学可以参考一下:

参考:

excel插件:/SheetJS/sheetjs

excel插件演示:http://demo.haoji.me//02/08-js-xlsx/

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。