问题提出

在使用 js 做 Excel 文件读取时,我们发现对于日期的处理很棘手。主要存在以下几种情况:

  • 所有的日期单元格读取到的是一个类似 44211.7533 的数字的问题
  • 格式不规范问题,如 2021-1-1 0:0:00
  • 按指定格式格式化的问题

带着这几个问题,我在网上找了几篇文章,但是都不能很好地解决,所以自己动手解决,并整理分享出来,希望对大家有所帮助

解决方案

/*** 处理从 Excel 单元格中读取到的日期格式的字段并转换为指定格式的日期字符串* * @param {string|number} date 从 Excel 单元格中读取到的日期格式* @param {string} fmt 要转换为的格式,默认 yyy-MM-dd HH:mm:ss*/
function handleDate(date, fmt) {if (!date) {return date;}date = date.trim ? date.trim() : date;if (/^[\d.]+$/.test(date)) {let dateNum = parseFloat(date);// 大于 1000 万说明是一个毫秒数,直接解析并转换为指定格式即可if (dateNum > 10000000) {return formatDate(dateNum, fmt);}// 否则认为这个是一个 Excel 格式的日期date = formatExcelDate(dateNum, fmt);console.log(date, typeof (date), dateNum)} else {// 处理中文冒号,和 yyyy/MM/dd 格式的问题date = date.replace(/:/g, ":").replace(/\//g, "-");}// 将不规则的格式,例如 "2020-1-1     1:3:3" 转换成 yyyy-MM-dd HH:mm:ss// 再转为 Date 对象进行指定的格式化console.log(date);let dtPars = date.split(/\s+/g)let dPars = dtPars[0].split("-");dPars[1] = padding2(dPars[1])dPars[2] = padding2(dPars[2])dtPars[0] = dPars.join("-");if (!dtPars[1]) {dtPars[1] = '00:00:00';} else {let tPars = dtPars[1].split(':');tPars[0] = padding2(tPars[0]);// 支持分缺失tPars[1] = padding2(tPars[1] || '00');// 支持秒缺失tPars[2] = padding2(tPars[2] || '00');dtPars[1] = tPars.join(':');}return formatDate(new Date(dtPars.join(" ")), fmt);
}/*** 缺位补0*/
function padding2(part) {if (part.length === 1) {return "0" + part} else {return part;}
}/*** 解析Excel表达的日期数字,并转换为指定格式的日期字符串* * @param {number} numb Excel解析出的数字形式的日期* @param {string} format 要转换为的格式,默认 yyy-MM-dd HH:mm:ss*/
function formatExcelDate(numb, format) {const time = new Date((numb - 2) * 24 * 3600000 + 1);time.setYear(time.getFullYear() - 70);time.setHours(time.getHours() - 8);return formatDate(time, format);
}/*** 日期格式转换* * @param {date|number} date 日期* @param {string} fmt 要转换为的格式,默认 yyy-MM-dd HH:mm:ss*/
function formatDate(date, fmt) {date = date == undefined ? new Date() : date;date = typeof date == 'number' ? new Date(date) : date;fmt = fmt || 'yyyy-MM-dd HH:mm:ss';let obj ={'y': date.getFullYear(), // 年份,注意必须用getFullYear'M': date.getMonth() + 1, // 月份,注意是从0-11'd': date.getDate(), // 日期'q': Math.floor((date.getMonth() + 3) / 3), // 季度'w': date.getDay(), // 星期,注意是0-6'H': date.getHours(), // 24小时制'h': date.getHours() % 12 == 0 ? 12 : date.getHours() % 12, // 12小时制'm': date.getMinutes(), // 分钟's': date.getSeconds(), // 秒'S': date.getMilliseconds() // 毫秒};let week = ['天', '一', '二', '三', '四', '五', '六'];for (let i in obj) {fmt = fmt.replace(new RegExp(i + '+', 'g'), function (m) {let val = obj[i] + '';if (i == 'w') return (m.length > 2 ? '星期' : '周') + week[val];for (let j = 0, len = val.length; j < m.length - len; j++) val = '0' + val;return m.length == 1 ? val : val.substring(val.length - m.length);});}return fmt;
}

使用示例

假设我们有这样一张 Excel 表:

id 姓名 签到时间 签退时间
1 张三 2021/1/1 8:00:00 2021/1/1 18:00:00
2 李四 2021/1/1 9:30:00 2021/1/1 19:15:00

我们使用 node-xlsx 读取:

const nodeXlsx = require('node-xlsx') //引用node-xlsx模块
var fs = require('fs');
// 读取excel表格
const ex1 = nodeXlsx.parse(filePath)//取出excel文件中的第一个工作表中的全部数据
let excel_content = ex1[0].data// 删掉表头
excel_content.splice(0, 1);
let records = excel_content.map(row => {return {id: row[0],name: row[1],startTime: handleDate(row[2], 'yyyy-MM-dd HH:mm:ss'),endTime: handleDate(row[3], 'yyyy-MM-dd HH:mm:ss')}
});
console.log(JSON.stringify(records))

这时我们将得到正确的日期格式结果:

[{"id": 1, "name": "张三", "startTime": "2021-01-01 08:00:00", "endTime": "2021-01-01 18:00:00"},
{"id": 2, "name": "李四", "startTime": "2021-01-01 09:30:00", "endTime": "2021-01-01 19:15:00"}]

js完美地处理转换 Excel 的日期格式相关推荐

  1. JS读取Excel时日期格式错误

    问题:在做项目的过程中遇到一个问题,导入excel数据时,发现日期的格式错误.预期效果是2022/1/2,导入后的效果却是44563.查阅资料后发现44563表示 1900年1月1号到2022年1月2 ...

  2. js将php时间戳转换成格式化日期

    //js将php时间戳转换成格式化日期function to_date(phpstr) {str = parseInt(phpstr) * 1000;//将php时间戳转化为整形并乘以1000var ...

  3. excel更改日期格式无效_Excel日期不会更改格式

    excel更改日期格式无效 Have you ever imported data into Excel, from your credit card statement, or somewhere ...

  4. Excel的日期格式约定与解析

    Excel的日期格式约定与解析 原理 当Excel单元格内容为=NOW()时,会显示当前的日期/时间,而倘若你将设置为单元格格式改为非日期时间的格式时,会显示一个非负实数. Excel 支持两个日期系 ...

  5. 关于excel导出日期格式变化问题处理

    关于excel导出日期格式变化问题处理 1.问题描述:java web项目,本来部署在windows下,导出数据库数据是,创建日期格式为2018-08-08 08:08:08.因服务器性能问题,迁移服 ...

  6. 根据当前日期进行以下方面的处理: 1、取得日期的年份、月份、天、时、分、秒,并转换成大写日期格式 如:2013年8月17日 20时30分20秒 2、根据日期的不同时间段,做问候语: 早上8:00-12

    根据当前日期进行以下方面的处理: 1.取得日期的年份.月份.天.时.分.秒,并转换成大写日期格式 如:2013年8月17日 20时30分20秒 2.根据日期的不同时间段,做问候语: 早上8:00-12 ...

  7. SQL Server 将JDE日期格式转换成常见日期格式

    SQL Server 将JDE日期格式转换成常见日期格式 JDE日期格式:JDE所有的日期字段在DB存储时用的是Julia date格式,总共6码,第一码代表世纪,二三码代表年份,后三码代表前三码所属 ...

  8. 电脑表格日期怎么修改原有日期_“电脑表格日期格式怎么改“如何把excel中日期格式设置为2001-01-01...

    如何在EXCEL中改变日期格式 1.打开需置日期格式的excel表. 2.选中日期所在的格,单击鼠键,选择"设置单元格格式"选项. 3.在弹对话框"数字"标签中 ...

  9. 【卡法 常用 ckl.js 库】: js汇合 表单验证 cookie设置 日期格式 电话手机号码 email 整数 小数 金额 检查参数长度...

    [卡法 常用js库]: js汇合 表单验证  cookie设置  日期格式  电话手机号码  email  整数  小数  金额   检查参数长度 // +---------------------- ...

最新文章

  1. Redis 怎么实现保存Django 查询集
  2. 成都大学的计算机排名,成都除了成都大学,还有2所985、4所211,含金量很高
  3. Win7如何改变用户文件夹位置
  4. 数据库迁移_数据库迁移了解一下
  5. 计算机应用基础形考作业3Excel,国家开放大学《计算机应用基础》考试与答案形考任务模块3 模块3 Excel 电子表格系统—客观题答案(2020年整理).pptx...
  6. CompletableFuture详解~思维导图
  7. 资源放送丨《MGR原理介绍与案例分享》PPT视频
  8. 【ElasticSearch】Es 源码之 ActionModule 源码解读
  9. HashMap 的 7 种遍历方式+性能分析!
  10. 数据挖掘技术之关联分析
  11. 记事本html表白,霸道总裁之代码强势表白
  12. 企业人力资源管理中的数据分析
  13. 基于OpenCV 的图像分割
  14. MySQL 打开视图 1449_Mysql查询视图:ERROR 1449 (HY000)
  15. 7 轮面试后,还是挂了 | Google 中国面经分享
  16. 滴水逆向三期笔记与作业——02C语言——02数据类型
  17. 腾讯云存储产品全线升级,满足更多高性能存储场景
  18. 6-4 计算圆柱体的表面积(函数名隐藏)
  19. 【Html+CSS】3D旋转相册
  20. 邻接矩阵,构造有向图、无向图、有向网、无向网,深度优先、广度优先遍历(C++图)

热门文章

  1. 数据库系统原理实验一——数据库定义实验
  2. 浅谈childNodes和children以及firstChild和firstElementChild
  3. python爬虫爬取wallpapers最新壁纸
  4. oracle alert很大,Oracle数据库案例整理-Oracle系统运行时故障-alert.log日志文件大小超出限制...
  5. 《云计算核心技术剖析》参考文献
  6. 时间不语,岁月要歌-我的2021
  7. 互联网行业哪个职位更有前途?
  8. python实现牛顿法_牛顿迭代法Python实现
  9. 京东商城刘强东他的创业经验和京东的发展思路
  10. 初学者入门课,Python入门体验之九九乘法表