vue使用XLSX 读取excel日期格式的单元格问题

最近要给一个vue项目,做一个excel模板导入功能,使用XLSX读取日期格式的单元格,解析出来总是一串数字,但是为规范模板填写的内容,必须对一些单元格进行日期格式设置。

查询资料,终于找到最简单的解决方案,读取excel,增加 cellDates: true 参数,如下:

var wb = XLSX.read(binary, {
  type: 'binary',
  cellDates: true
})

记录下来,给有需要的人!

基于有小伙伴问,解析出来的日期类似2024-03-21T15:59:17.000Z这种格式,这是日期格式,针对后台的日期类型字段,可以直接存储,展示时候需要格式化一下,有两种方式可以处理日期字段的展示:

1.可以在后台日期属性的字段上加注解

@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")

private Date createTime;

2.可以在前端展示时候格式化处理

function parseTime(time, pattern) {
  if (arguments.length === 0 || !time) {
    return null
  }
  const format = pattern || '{y}-{m}-{d} {h}:{i}:{s}'
  let date
  if (typeof time === 'object') {
    date = time
  } else {
    if ((typeof time === 'string') && (/^[0-9]+$/.test(time))) {
      time = parseInt(time)
    } else if (typeof time === 'string') {
      time = time.replace(new RegExp(/-/gm), '/').replace('T', ' ').replace(new RegExp(/\.[\d]{3}/gm), '');
    }
    if ((typeof time === 'number') && (time.toString().length === 10)) {
      time = time * 1000
    }
    date = new Date(time)
  }
  const formatObj = {
    y: date.getFullYear(),
    m: date.getMonth() + 1,
    d: date.getDate(),
    h: date.getHours(),
    i: date.getMinutes(),
    s: date.getSeconds(),
    a: date.getDay()
  }
  const time_str = format.replace(/{(y|m|d|h|i|s|a)+}/g, (result, key) => {
    let value = formatObj[key]
    // Note: getDay() returns 0 on Sunday
    if (key === 'a') { return ['日', '一', '二', '三', '四', '五', '六'][value] }
    if (result.length > 0 && value < 10) {
      value = '0' + value
    }
    return value || 0
  })
  return time_str
}

另:

XLSX将excel中的日期内容解析后会发现,比实际填写的小一天,处理方式就是,解析表格数据时候把日期格式的字段格式化一下,加1天,具体代码如下:

excelDateFormat(date) { // 日期转换
  if (date === undefined || date === null || date === '') {
    return null
  }
  // 非时间格式问题  返回Invalid date
  const retFormat = moment(date).format('YYYY-MM-DD')
  if (retFormat === 'Invalid date') {
    return retFormat
  }
  return moment(date).add(1, 'days').format('YYYY-MM-DD')
},

用法:

当然,如果整列数据比较规范,不像我这种需要一个单元格一个单元格的去读数据的情形,可以批量处理:

excelDateFormat(row, columnName) { // 日期转换
  var date = row[columnName]
  if (date === undefined || date === null || date === '') {
    return null
  }
  // 非时间格式问题  返回Invalid date
  const retFormat = moment(date).format('YYYY-MM-DD')
  if (retFormat === 'Invalid date') {
    return retFormat
  }
  return moment(date).add(1, 'days').format('YYYY-MM-DD')
},

结语:记录使我快乐,能帮助到大家,我更快乐!

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值