VUE中xslx解析excel日期格式问题

1.第一种方法

配置的readerData方法中const workbook = XLSX.read(data, { type: 'array' })

当excel上传日期时获取的为字符串,例如:excel文件中日期为2023/5/23,拿到的数据为45069

在导入数据前对数据做yyyy-MM-dd处理

复制代码
   /** 导入数据部分过滤器 */
   importFilter(batchSaveData){
       //这里执行需要过滤的信息
       for(var i=0;i<batchSaveData.length;i++){
           if( batchSaveData[i].buyDate){
               try {
                 batchSaveData[i].buyDate = this.formDate(batchSaveData[i].buyDate);
                 console.log(batchSaveData[i].buyDate);
               } catch (error) {
                   throw new Error("时间格式错误"); 
               }
           }
     
         }
       return  batchSaveData;
   },
   formDate(date){
     // 将Excel日期转换为JavaScript日期
     const jsDate = new Date((date - 25569) * 86400 * 1000);
     // 将JavaScript日期转换为指定格式:yyyy-MM-dd
     const year = jsDate.getFullYear();
     const month = String(jsDate.getMonth() + 1).padStart(2, '0');
     const day = String(jsDate.getDate()).padStart(2, '0');
     return `${year}-${month}-${day}`;
   },

1.第二种方法

配置的readerData方法中配置cellDates: true, dateNF: "yyyy-MM-dd HH:mm",可处理时间格式

复制代码
const workbook = XLSX.read(data, { type: 'array', cellDates: true, dateNF: "yyyy-MM-dd HH:mm" })

获取的日期:Mon May 22 2023 23:59:17 GMT+0800

但获取的格式少43秒,存入数据库中会少一天

处理方法:获取的日期+44秒

const timestamp = batchSaveData[i].buyDate.getTime() + (44 * 1000);

batchSaveData[i].buyDate = new Date(timestamp);

复制代码
    /** 导入数据部分过滤器 */
   importFilter(batchSaveData){
       //这里执行需要过滤的信息
       for(var i=0;i<batchSaveData.length;i++){
           if( batchSaveData[i].buyDate){
               try {
                 console.log(batchSaveData[i].buyDate);
                 const timestamp = batchSaveData[i].buyDate.getTime() + (44 * 1000);
                 batchSaveData[i].buyDate = new Date(timestamp);
                 batchSaveData[i].buyDate = this.parseTime(batchSaveData[i].buyDate,"{y}-{m}-{d}");
                 // batchSaveData[i].buyDate = this.formDate(batchSaveData[i].buyDate);
                 console.log(batchSaveData[i].buyDate);
               } catch (error) {
                   throw new Error("时间格式错误"); 
               }
           }
       }
       return  batchSaveData;
   },
相关推荐
东华帝君9 小时前
vue3自定义v-model
前端
JIngJaneIL9 小时前
远程在线诊疗|在线诊疗|基于java和小程序的在线诊疗系统小程序设计与实现(源码+数据库+文档)
java·数据库·vue.js·spring boot·小程序·毕设·在线诊疗小程序
fruge10 小时前
搭建个人博客 / 简历网站:从设计到部署的全流程(含响应式适配)
前端
光影少年10 小时前
css影响性能及优化方案都有哪些
前端·css
呆呆敲代码的小Y10 小时前
2025年多家海外代理IP实战案例横向测评,挑选适合自己的
前端·产品
q***37510 小时前
爬虫学习 01 Web Scraper的使用
前端·爬虫·学习
v***56510 小时前
Spring Cloud Gateway
android·前端·后端
b***594310 小时前
分布式WEB应用中会话管理的变迁之路
前端·分布式
q***216011 小时前
Spring Boot项目接收前端参数的11种方式
前端·spring boot·后端
顾安r11 小时前
11.21 脚本 网页优化
linux·前端·javascript·算法·html