当前位置: 首页 > news >正文

SheetJS的部分操作

成文时间:2023年2月18日
使用版本:"xlsx": "^0.18.5"

碎碎念:
有错请指正。
这个库自说自话升级到0.19。旧版的文档我记得当时是直接写在github的README上。
我不太会使用github,现在我不知道去哪里可以找到旧版的文档。
这种感觉让你觉得很无助,使用这样的库确实是没啥安全感。
代码修修改改是正常的,回头找不到文档了这算是什么事。。
当然,开源分享本身已经是伟大而值得尊敬的事。
作为伸手党也不能多比比什么。所以我这次使用希望把操作多积累下来一点,以防再遇到背刺吧。

文章目录

  • 读取文件
  • 排序

读取文件

        const reader = new FileReader();reader.readAsArrayBuffer(file);reader.onload = (e) => {let data = e.target.result;let wb = read(data)let sheets = wb.Sheets;// 获取json格式的数据let json_data = utils.sheet_to_json(sheets[wb.SheetNames[0]])// 取出header(json的属性key)let columns = Object.keys(json_data[0]).map((r) => (r))

sheet_to_json这里有个参数很奇怪,他文档示例里面的header
在这里插入图片描述
在这里插入图片描述
代码里面也确认有这个参数
用‘A’的时候,他会把json的属性名称都用字母表示,这样你就不用像我排序那节里面说的还需要一堆操作去获取属性名称了。
用string[]的时候也没问题,就是如果你给的List不够长。比如文件有6个列,你只给了5个string,会导致文件被截断成5列。
这个number的参数我很奇怪,一直没办法成功。我的理解是应该是指定一个行来生成属性名称
他的原文Create an array of arrays of JS values from a worksheet
但是我设置成啥数字都没效果,升级成文档对应的19版本也不行。使用时请注意。

排序

			// 指定排序的规则let sortList = sortSetting.split('|')// 指定排序列let sortColNum = utils.decode_col(sortCol)let sortColName = columns[sortColNum]// 过滤数据json_data = json_data.filter(item=>{return sortList.indexOf(item[sortColName]) >= 0})// 数据排序json_data.sort(function(a,b){return sortList.indexOf(a[sortColName]) - sortList.indexOf(b[sortColName]);});
http://www.lryc.cn/news/12446.html

相关文章:

  • pytest总结
  • CNI 网络分析(九)Calico IPIP
  • 分布式任务调度(XXL-JOB)
  • Django框架之模型视图--Session
  • 二极管的“几种”应用
  • github上传本地文件详细过程
  • 常用聚类算法分析
  • OSG三维渲染引擎编程学习之五十八:“第五章:OSG场景渲染” 之 “5.16 简单光源”
  • 80211无线网络架构
  • 基于springboot+vue的便利店库存管理系统
  • 3|物联网控制|计算机控制-刘川来胡乃平版|第1章:绪论|青岛科技大学课堂笔记|U1 ppt
  • js打印本地pdf(使用HttpPrinter打印插件)
  • 华为OD机试 - 双十一(Python) | 机试题算法思路 【2023】
  • 2020年UML 秋季期末测试题
  • SpringCloud - Ribbon负载均衡
  • Spring Boot + Redis 实现分布式锁
  • CAD二次开发 插件初始化接口IExtensionApplication
  • kafka-11-kafka的监控工具和常用配置参数
  • 前端PWA渐进式加载技术
  • 【ubuntu 22.04不识别ch340串口】
  • 解决:eclipse绿化版Resource注解报Resource cannot be resolved to a type问题
  • 初识Cookie和Session
  • vue3的七种路由守卫使用
  • 华测导航GPCHC协议ROS驱动包,CGI610、410接收机,NavSatStatus、GPSFix和普通格式
  • 算法实战应用案例精讲-【图像处理】Pillow图像处理(python代码实战)
  • C语言通讯录【动态+文件】
  • Linux驱动开发详细解析
  • Java Character 类,超详细整理,适合新手入门
  • Python量化入门:关于收益率的一些概念
  • 微搭使用笔记(三) 数据模型介绍及初步使用