快捷搜索:  汽车  科技

xlsx如何跳着复制单元格:给空的单元格赋值为空字符串

xlsx如何跳着复制单元格:给空的单元格赋值为空字符串const sheet2JSONOpts = { /** Default value for null/undefined values */ defval: ''//给defval赋值为空的字符串 } //调用方法 const results = XLSX.utils.sheet_to_json(worksheet sheet2JSONOpts) console.log(results) 最后,结果成功解决我问题,如下图所示在用一些插件的时候,有些问题,其实可以通过看源码来找到很好的解决方法,插件会封装好一些方法,来给我们调用。

前言

今天用到XLSX来解析excel文件,调用XLSX.utils.sheet_to_json(worksheet),发现如果单元格为空的话,解析出来的结果,就会缺少相应的key(如图所示)。但是我想要单元格为空的话,值就默认给空字符串,怎么办呢?只能去看看源码了,看有没有给默认值的方法。

xlsx如何跳着复制单元格:给空的单元格赋值为空字符串(1)

xlsx如何跳着复制单元格:给空的单元格赋值为空字符串(2)

源码探究

找源码里的sheet_to_json()方法,发现有三个同名的方法 有两个参数,第一个worksheet是要解析的excel文件的工作簿对象,第二参数opts?: Sheet2JSONOpts,
?表示是这个参数可有可无,你不传就没有,Sheet2JSONOpts这个是什么东西?我也不知道,只能接着往下看源码有没有这个东西的定义。(一般都会有)

xlsx如何跳着复制单元格:给空的单元格赋值为空字符串(3)


果然,如我所料,终于在源码找到Sheet2JSONOpts的定义,发现有五个变量,这五个变量都带?,说明这个五个变量都可有可无。然后我就看到图中红框的部分,发现注释写着Default value for null/undefined values,意思是值为空或未定义的默认值变量。这是不就是我要找的解决方法了吗?高兴得赶紧去实现一下。

xlsx如何跳着复制单元格:给空的单元格赋值为空字符串(4)

解决

按照源码来定义第二个参数,给defval赋值为空的字符串,如代码所示

const sheet2JSONOpts = { /** Default value for null/undefined values */ defval: ''//给defval赋值为空的字符串 } //调用方法 const results = XLSX.utils.sheet_to_json(worksheet sheet2JSONOpts) console.log(results)

最后,结果成功解决我问题,如下图所示

xlsx如何跳着复制单元格:给空的单元格赋值为空字符串(5)

总结

在用一些插件的时候,有些问题,其实可以通过看源码来找到很好的解决方法,插件会封装好一些方法,来给我们调用。

猜您喜欢: