zoukankan      html  css  js  c++  java
  • xlsx插件处理日期格式,以及某列第一行无数据情况 列不显示问题

    1.问题:日期格式会显示数字

     解决方法:XLSX.read的配置项里 设置 cellDates: 'd'

          设置好后会显示标准日期格式,配置项里有 dateNF是可以设置日期格式的,但是我还没弄清,就手动处理了下

          看红色字体部分

    2.问题:如果第一行数据的某一列是空值,这一列回不显示

     解决方法:

        在XLSX.utils.sheet_to_json这个方法里添加配置项, 给空值添加一个默认值,如图蓝色字部分    

    // 通过DOM取文件数据
                this.file = event.currentTarget.files[0];
                var rABS = false; //是否将文件读取为二进制字符串
                var f = this.file;
                var reader = new FileReader();
                FileReader.prototype.readAsBinaryString = function(f) {
                    _this.excelDialogInfo.isShowExcelDialog = true;
                    var binary = "";
                    var rABS = false; //是否将文件读取为二进制字符串
                    var wb; //读取完成的数据
                    var outdata;
                    var reader = new FileReader();
                    reader.onload = function(e) {
                        var bytes = new Uint8Array(reader.result);
                        var length = bytes.byteLength;
                        for(var i = 0; i < length; i++) {
                            binary += String.fromCharCode(bytes[i]);
                        }
                        var XLSX = require('xlsx');
                        if(rABS) {
                            wb = XLSX.read(btoa(fixdata(binary)), { //手动转化
                                type: 'base64'
                            });
                        } else {
                            wb = XLSX.read(binary, {
                                type: 'binary',
                                cellDates: true
                            });
                    for (const i in wb.Sheets[wb.SheetNames[0]]) {
                      if(wb.Sheets[wb.SheetNames[0]][i]['v'] !== null && wb.Sheets[wb.SheetNames[0]][i]['v'] !== undefined && wb.Sheets[wb.SheetNames[0]][i]['t'] == 'd'){
                        wb.Sheets[wb.SheetNames[0]][i]['v'] = _this.dateFormat(new Date(wb.Sheets[wb.SheetNames[0]][i]['w']), 'yyyy/MM/dd');
                      }
                    }
    
                        }
                        outdata = XLSX.utils.sheet_to_json(wb.Sheets[wb.SheetNames[0]], {
                        defval: ''
                   }
    );  //到这里就是获取到数据了
                // 下面时在文件中记录数据 自行修改
                        if(outdata && outdata.length > 0){
                            let columns = [];
                            console.log(outdata[0]);
                            for(let key in outdata[0]){
                                columns.push({
                                    field: key,
                                });
                            }
                            _this.excelDialogInfo.columns = columns;
                            _this.excelDialogInfo.data = outdata;
                        }else{
                            MessageBox.alert('所选表格数据为空,请重新选择', '消息', {type: 'warning'});
                        }
    
               }
                    reader.readAsArrayBuffer(f);
                }
                if(rABS) {
                    reader.readAsArrayBuffer(f);
                } else {
                    reader.readAsBinaryString(f);
                }
            })
  • 相关阅读:
    数据预处理
    机器学习--有监督学习和无监督学习
    weka简介
    第10章 接口、继承与多态----类的继承3
    html5 canvas实现梦幻的3D刺猬球
    html5 canvas实现图片玻璃碎片特效
    css3实现的鼠标经过按钮特效
    CSS3 Transitions属性打造动画的下载按钮特效
    纯css3实现的幽灵按钮导航
    几行css3代码实现超炫加载动画
  • 原文地址:https://www.cnblogs.com/Mr-Rshare/p/12851909.html
Copyright © 2011-2022 走看看