• 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)
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    最后,结果成功解决我问题,如下图所示
    请添加图片描述
    总结
    在用一些插件的时候,有些问题,其实可以通过看源码来找到很好的解决方法,插件会封装好一些方法,来给我们调用。

  • 相关阅读:
    mybatis传递参数
    06-添加用户关注、我的关注列表
    修改ant-design-vue的switch样式,去除顿顿的样式
    JMeter 进行函数助手MD5加密
    JVM类加载机制详解
    docker安装可视化工具portainer中文版
    小程序中如何设置门店信息
    CoCube和Micro-ROS简单案例演示
    switch-case语句中声明定义的使用
    课堂练习10 python数据库编程
  • 原文地址:https://blog.csdn.net/weixin_34403976/article/details/133701767