• 首页 首页 icon
  • 工具库 工具库 icon
    • IP查询 IP查询 icon
  • 内容库 内容库 icon
    • 快讯库 快讯库 icon
    • 精品库 精品库 icon
    • 问答库 问答库 icon
  • 更多 更多 icon
    • 服务条款 服务条款 icon

JS读取Excel时日期格式错误

武飞扬头像
一只美团熊
帮助1

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

方法一(不推荐)

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

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

方法二(推荐)

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

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

这篇好文章是转载于:学新通技术网

  • 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
  • 本站站名: 学新通技术网
  • 本文地址: /boutique/detail/tanhghcceg
系列文章
更多 icon
同类精品
更多 icon
继续加载