JS读取Excel时日期格式错误

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

方法一(不推荐)

formatDate(numb, format) {
  const time = new Date((numb - 1) * 24 * 3600000 + 1);
  time.setYear(time.getFullYear() - 70)
  const year = time.getFullYear() ;
  const month = time.getMonth() + 1 ;
  const date = time.getDate() - 1 ;
  return year + format + (month < 10 ? '0' + month : month) + format + (date < 10 ? '0' + date : date)
},

这种方法有一定的瑕疵,在某些特定的时间会出现偏差,例如2022/03/08这天,导入输入后显示的是2022/03/07。比原数据少一天。

方法二(推荐)

formatDate(numb, format) {
        //参数numb是间隔天数,format是自定义的日期分隔符。
        console.log(numb)
        //打印出来的结果是44563,表示1900年1月1日到当前日期的天数
        let getDay = numb - 1
        let t = Math.round((getDay - Math.floor(getDay)) * 24 * 60 * 60)
        //当导入的excel日期中包含了时分秒,t则表示小数点后面的时间
        let time = new Date(1900, 0, getDay, 0, 0, t);
        //getDay是从1900开始计算的,因此new Date()的第一个参数是1900
        let year = time.getFullYear();
        let month = time.getMonth() + 1;
        let date = time.getDate();
        return year + format + (month < 10 ? "0" + month : month) + format + (date < 10 ? "0" + date : date);
    },

这种方法就能够完美解决JS读取Excel时日期格式错误的问题,希望能对各位有所帮助。

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值