zoukankan      html  css  js  c++  java
  • 使用XLSX.utils.sheet_to_json()解析excel,给空的单元格赋值为空字符串

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


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

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


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

    const sheet2JSONOpts = {
    /** Default value for null/undefined values */
    defval: ''//给defval赋值为空的字符串
    }
    //调用方法
    const results = XLSX.utils.sheet_to_json(worksheet, sheet2JSONOpts)
    console.log(results)
     
    最后,结果成功解决我问题,如下图所示


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


    ————————————————
    版权声明:本文为CSDN博主「码上云端」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
    原文链接:https://blog.csdn.net/weixin_43817709/article/details/103754546

  • 相关阅读:
    酷狗大数据平台架构是如何重构的
    分层架构,前后端分离有啥坏处?
    Redis快速入门及应用
    Kafka不只是个消息系统
    提高代码质量:如何编写函数
    jquery 回车事件
    程序员的薪资是如何确定出来的?
    HTTP 错误 500.21
    制作手机浏览器显示格式的HTML页面
    操作必须使用一个可更新的查询。
  • 原文地址:https://www.cnblogs.com/javalinux/p/15631834.html
Copyright © 2011-2022 走看看