关于解析Excel中的日期出现是数字序列的问题

使用xlsx.js读取Excel中的日期有两种方式:

  1. XLSX.read(file, { type: 'binary' })

  2. XLSX.read(file, { type: 'binary', cellDates: true })

第一种方式得到的是一个 1900-01-01 00:00:00 开始的序列号。

复制代码
export function formatExcelDate(excelSerialDate) {
  //  25569 是 1970-01-01 对应的 Excel 序列号, Excel 时间起点:1900-01-01 00:00:00 , JS 时间起点:1970-01-01 00:00:00
  // 86400 * 1000 = 一天的毫秒数
  // console.log(new Date(Math.round((excelSerialDate - 25569) * 86400 * 1000)))
  return new Date(Math.round((excelSerialDate - 25569) * 86400 * 1000));
}

1. 为什么需要 excelSerialDate - 25569

excelSerialDate - 25569 目的是得到1970年1月1日至被计算的日期(excelSerialDate)相差了多少天。

2. 25569 表示1900-01-01 到 1970-01-01 有多少天,如何计算的

70年 × 365天 = 25550 天

加上闰年(1904,1908,...,1968)共 17 天

加上 Excel 闰年 bug(1900被误认为闰年)1 天

加上第1天从1开始而不是0的偏移 1 天

总计:25550 + 17 + 1 + 1 = 25569 天

3. Math.round 的作用

由于JS 使用 IEE 754 双精度浮点数表示数字,有些乘法会产生不准确的结果。

例如: 0.1 + 0.2 = 0.30000000000000004

为了解决精度问题,所以使用 Math.round 四舍五入。

4. 为什么需要转成 JS Date

JS Date 使用毫秒时间戳,所以使用 excelSerialDate - 25569 计算出从 JS 时间起点(1970-01-01)到目标日期的天数,然后乘以一天的毫秒数就得到了 JS 时间戳。

测试

复制代码
// 使用示例
const excelDate = 46170;
const jsDate = excelDateToJSDate(excelDate);
console.log(jsDate); // 2026-05-28T00:00:00.000Z

第二种方式得到是一个Date类型的数据

相关推荐
jarreyer13 小时前
【数据分析绘图】excel绘图和bi工具区别
数据挖掘·数据分析·excel
chatexcel14 小时前
ChatExcel Max使用教程:图片、PDF、网页与复杂Excel的一站式数据分析
数据分析·pdf·excel
cngkqy14 小时前
excel从某一列中用match筛选匹配的数据
excel
qq_5469372715 小时前
Excel批量转PDF_Word_图片,支持自动合并报表,效率翻倍。
pdf·word·excel
ai_coder_ai15 小时前
在自动化脚本中操作excel文件
运维·自动化·excel
三千花灯15 小时前
【Playwright】 自动化测试之参数化登录(Excel/CSV 数据源)
人工智能·机器学习·excel
罗政16 小时前
AI工作流实现Excel全自动化(支持SQL)-案例:医院门诊排班表
人工智能·自动化·excel
小妖66616 小时前
excel 怎么在单元格内容自动加上一段文字不能用公式
excel·vba
asdzx672 天前
Python 优雅解析 Excel:从原生行列到强类型对象的三层数据结构演进
数据结构·python·excel
罗政2 天前
AI工作流实现Excel自动化+SQL,零 VBA ,零公式,电商订单分析案例 | DTBot
sql·自动化·excel