「趣学前端」实现读取excel文件内容小功能

本文涉及的产品
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
全局流量管理 GTM,标准版 1个月
简介: 用技术实现梦想,用梦想打开前端技术之门。分享一下读取excel文件内容小功能是如何实现的。

前言

我们在做业务需求的时候,会遇到展示表格的页面,如果只有一个表格,我们可以直接把内容填充到我们的代码中,有时候业务需要不同的分类展示不同的表格,而表格内容是静态的,这类需求,我之前的处理是写个本地json文件,每次新增让产品直接把数据录到json文件中。有时候业务会把Excel表格发给我,我自己进行录入。闲暇的时候我在想,可否通过解析Excel文件直接拿到内容呢?


于是我进行了后面的尝试。


Excel文件的读取

目标功能

我想实现的功能主要有几部分:读取Excel文件,识别多个工作表,每个工作表按行将数据放入数组中。最终解析输入如下:

Excel文件数据

两个工作表:鞋子和裤子

image.jpeg


image.jpeg

读取的完整数据

{
"fileName": "测试读取.xlsx",
"list": [
        {
"sheetName": "鞋子",
"list": [
                {
"goodName": "鞋子A版",
"size": "37",
"color": "白色"                },
                {
"goodName": "鞋子B版",
"size": "38",
"color": "米色"                },
                {
"goodName": "鞋子C版",
"size": "38",
"color": "黑色"                }
            ]
        },
        {
"sheetName": "裤子",
"list": [
                {
"goodName": "裤子A版",
"size": "S",
"color": "白色"                },
                {
"goodName": "裤子B版",
"size": "M",
"color": "黑色"                },
                {
"goodName": "裤子C版",
"size": "L",
"color": "红色"                },
                {
"goodName": "裤子D版",
"size": "XL",
"color": "紫色"                }
            ]
        }
    ]
}


下面我将功能进行细分。

读取Excel文件

解析插件

插件:xlsx.core.min.js

官网:https://github.com/sheetjs/sheetjs


读取方法

FileReader可以读取Excel文件内容,它的详细知识点可以查看MDN

我这里使用的FileReader.readAsBinaryString(file) :开始读取指定的Blob中的内容。一旦完成,result属性中将包含所读取文件的原始二进制数据。


HTML部分

包括文件上传和数据内容展示两部分,其中文件上传有限制文件类型必须是.xls或.xlsx后缀的。

<!DOCTYPEhtml><html><head><title>读取excel文件解析内容</title><scriptsrc="https://cdn.bootcss.com/xlsx/0.11.5/xlsx.core.min.js"></script><style>      .warp {
width: 100%;
display: flex;
justify-content: flex-start;
margin-top: 10px;
      }
span {
display: block;
      }
textarea {
width: 80%;
display: block;
      }
      .file {
margin-bottom: 15px;
      }
      .tip {
margin-bottom: 15px;
      }
</style></head><body><h3class="tip">目前只能解析简单的纵向列表数据,支持多个工作表</h3><divclass="file"><inputtype="file"accept=".xls,.xlsx"onchange="uploadFile(this)"id="myFile"/></div><divclass="warp"><span>内容展示:</span><textareaid="content"rows="30"></textarea></div></body></html>

上传操作方法

先判断上传文件是否为空,如果不为空才进行下一步。

/** * 文件上传操作 * @param {Element} obj 选择的文件元素 * @return {void} 无 */functionuploadFile(obj) {
//导入if (!obj.files) {
return;
  }
letf=obj.files[0];
readExcelFile(obj, f);
}


文件读取

XLSX为sheetjs插件提供的方法

  • XLSX.read(data, read_opts):尝试解析data
  • workbook.SheetNames 是工作簿中工作表的有序列表;
  • wb.Sheets[sheetname] 返回一个代表工作表的对象;
  • XLSX.utils.sheet_to_json生成不同类型的 JS 对象。
/** @name 读取完成的数据 */varjsonContent;
/** * Excel文件处理方法 * @param {Element} obj 选择的文件元素 * @param {File} f 文件对象 * @return {void} 无 */functionreadExcelFile(obj, f) {
varreader=newFileReader();
reader.onload=function (e) {
vardata=e.target.result;
jsonContent=XLSX.read(data, {
type: 'binary',
    });
/** @name 工作簿中工作表的有序列表 */constsheetNamesList=jsonContent.SheetNames;
constsheetsList= [];
sheetNamesList.map(sheetItem=> {
//jsonContent.Sheets[Sheet名]获取该Sheet的数据constsheetItemData=jsonContent.Sheets[sheetItem];
sheetsList.push({
sheetName: sheetItem,
list: XLSX.utils.sheet_to_json(sheetItemData), // 数据转成json格式      });
    });
pageShow(sheetsList, f);
  };
reader.readAsBinaryString(f);
}


重组Excel文件数据

  • 现在的数据key为工作表表头的值,是中文名称,可以根据定义的变量名进行数据重组,所以我加了一个变量枚举renameObj。注:如果多个工作表的表头不一致,可重置renameObj对象,并改造resetTableData方法内的代码即可;
  • resetTableData方法会将数据的所有key替换成枚举中的变量值;
  • 变量arrayData为最终的处理之后的Excel数据,这时已经将Excel文件中的数据处理成了方便前端在页面回显的数据。
/** * 重组key-value * @param {Array} list 需要操作的数组 * @param {Object} renameObj 重命名变量对象 * @return {Array} 合并成的新数组 */functionresetTableData(list, renameObj) {
letnewList= [].concat(list);
newList.map(item=> {
for (letkinitem) {
constrenameKey=renameObj[k];
item[renameKey] =item[k];
deleteitem[k];
    }
  });
returnnewList; // 最终输出}
/** * 数据回显 * @param {Array} list 数据数组对象 * @param {File} f 文件对象 * @return {void} 无 */functionpageShow(list, f) {
letjsonData='';
/** @name 列表展示的变量名枚举 */constrenameObj= {
商品名: 'goodName',
大小: 'size',
颜色: 'color',
  };
letnewList= [].concat(list);
newList.map(item=> {
item.list=resetTableData(item.list, renameObj);
  });
/** @name 最终的数据 */letarrayData= {
fileName: f.name,
list: [].concat(newList),
  };
constcontent=document.getElementById('content');
jsonData=JSON.stringify(arrayData, null, 4);
content.innerHTML=jsonData;
}


浏览器展示

image.jpeg

完整代码

<!DOCTYPEhtml><html><head><title>读取excel文件解析内容</title><scriptsrc="https://cdn.bootcss.com/xlsx/0.11.5/xlsx.core.min.js"></script><style>      .warp {
width: 100%;
display: flex;
justify-content: flex-start;
margin-top: 10px;
      }
span {
display: block;
      }
textarea {
width: 80%;
display: block;
      }
      .file {
margin-bottom: 15px;
      }
      .tip {
margin-bottom: 15px;
      }
</style></head><body><h3class="tip">目前只能解析简单的纵向列表数据,支持多个工作表</h3><divclass="file"><inputtype="file"accept=".xls,.xlsx"onchange="uploadFile(this)"id="myFile"/></div><divclass="warp"><span>内容展示:</span><textareaid="content"rows="30"></textarea></div></body><scripttype="text/javascript">/**     *FileReader读取方法:readAsBinaryString(file):开始读取指定的Blob中的内容。一旦完成,result属性中将包含所读取文件的原始二进制数据。     *@return {void} 无     **//** @name 读取完成的数据 */varjsonContent;
/**     * 文件上传操作     * @param {Element} obj 选择的文件元素     * @return {void} 无     */functionuploadFile(obj) {
//导入if (!obj.files) {
return;
      }
letf=obj.files[0];
readExcelFile(obj, f);
    }
/**     * Excel文件处理方法     * @param {Element} obj 选择的文件元素     * @param {File} f 文件对象     * @return {void} 无     */functionreadExcelFile(obj, f) {
varreader=newFileReader();
reader.onload=function (e) {
vardata=e.target.result;
jsonContent=XLSX.read(data, {
type: 'binary',
        });
/** @name 工作簿中工作表的有序列表 */constsheetNamesList=jsonContent.SheetNames;
constsheetsList= [];
sheetNamesList.map(sheetItem=> {
//jsonContent.Sheets[Sheet名]获取该Sheet的数据constsheetItemData=jsonContent.Sheets[sheetItem];
sheetsList.push({
sheetName: sheetItem,
list: XLSX.utils.sheet_to_json(sheetItemData), // 数据转成json格式          });
        });
pageShow(sheetsList, f);
      };
reader.readAsBinaryString(f);
    }
/**     * 重组key-value     * @param {Array} list 需要操作的数组     * @param {Object} renameObj 重命名变量对象     * @return {Array} 合并成的新数组     */functionresetTableData(list, renameObj) {
letnewList= [].concat(list);
newList.map(item=> {
for (letkinitem) {
constrenameKey=renameObj[k];
item[renameKey] =item[k];
deleteitem[k];
        }
      });
returnnewList; // 最终输出    }
/**     * 数据回显     * @param {Array} list 数据数组对象     * @param {File} f 文件对象     * @return {void} 无     */functionpageShow(list, f) {
letjsonData='';
/** @name 列表展示的变量名枚举 */constrenameObj= {
商品名: 'goodName',
大小: 'size',
颜色: 'color',
      };
letnewList= [].concat(list);
newList.map(item=> {
item.list=resetTableData(item.list, renameObj);
      });
/** @name 最终的数据 */letarrayData= {
fileName: f.name,
list: [].concat(newList),
      };
constcontent=document.getElementById('content');
jsonData=JSON.stringify(arrayData, null, 4);
content.innerHTML=jsonData;
    }
</script></html>


总结

日常开发中,如果觉得哪些不方便、不顺手的,不妨写个小工具协助开发,避免简单的重复的工作占用我们过多的时间。

目录
相关文章
|
3天前
|
人工智能 自然语言处理 Java
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
FastExcel 是一款基于 Java 的高性能 Excel 处理工具,专注于优化大规模数据处理,提供简洁易用的 API 和流式操作能力,支持从 EasyExcel 无缝迁移。
47 9
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
|
30天前
|
Python
按条件将Excel文件拆分到不同的工作表
使用Python的pandas库,可以轻松将Excel文件按条件拆分到不同的工作表中。本文通过一个示例代码展示了如何生成一个包含总成绩表和三个班级表的Excel文件。代码首先创建了一个包含学生姓名、班级和各科成绩的数据框,然后按班级分组,将每个班级的数据分别写入不同的工作表。最后,生成的Excel文件将包含四个工作表,分别为总成绩表和三个班级的成绩表。
32 6
按条件将Excel文件拆分到不同的工作表
|
30天前
|
数据可视化 数据处理 Python
使用Pandas实现Excel中的数据透视表功能
本文介绍了如何使用Python的Pandas库实现Excel中的数据透视表功能,包括环境准备、创建模拟销售数据、代码实现及输出等步骤。通过具体示例展示了按地区和销售员汇总销售额的不同方法,如求和、平均值、最大值等,帮助读者掌握Pandas在数据处理上的强大能力。
60 12
|
29天前
|
Python
批量将不同的工作簿合并到同一个Excel文件
本文介绍如何使用Python的`pandas`库批量合并不同工作簿至同一Excel文件。通过模拟生成三个班级的成绩数据,分别保存为Excel文件,再将这些文件合并成一个包含所有班级成绩的总成绩单。步骤包括安装必要库、生成数据、保存与合并工作簿。
39 6
|
29天前
|
Python
按条件将Excel文件拆分到不同的工作表
使用Python的pandas库,可以轻松将Excel文件按条件拆分为多个工作表。本文通过一个具体示例,展示了如何根据学生班级将成绩数据拆分到不同的工作表中,并生成一个包含总成绩表和各班级成绩表的Excel文件。代码简洁明了,适合初学者学习和应用。
40 6
|
2月前
|
前端开发
实现Excel文件和其他文件导出为压缩包,并导入
实现Excel文件和其他文件导出为压缩包,并导入
32 1
|
2月前
|
前端开发 Java easyexcel
SpringBoot操作Excel实现单文件上传、多文件上传、下载、读取内容等功能
SpringBoot操作Excel实现单文件上传、多文件上传、下载、读取内容等功能
131 8
|
2月前
|
JSON 前端开发 搜索推荐
惊!这些前端技术竟然能让你的网站实现个性化推荐功能!
【10月更文挑战第30天】随着互联网技术的发展,个性化推荐已成为提升用户体验的重要手段。前端技术如JavaScript通过捕获用户行为数据、实时更新推荐结果等方式,在实现个性化推荐中扮演关键角色。本文将深入解析这些技术,并通过示例代码展示其实际应用。
91 4
|
2月前
|
存储 Java API
Java实现导出多个excel表打包到zip文件中,供客户端另存为窗口下载
Java实现导出多个excel表打包到zip文件中,供客户端另存为窗口下载
81 4
|
3月前
|
JavaScript 前端开发 数据处理
Vue导出el-table表格为Excel文件的两种方式
Vue导出el-table表格为Excel文件的两种方式
122 6