首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Sheetjs只读取前1000行

Sheetjs只读取前1000行
EN

Stack Overflow用户
提问于 2018-10-29 12:23:52
回答 1查看 859关注 0票数 0

我使用sheetjs将excel文件导入到数据库中。一切正常,但它只导入前1000行。

下面是我的代码:当用户在输入字段中加载一个文件时,它会创建一个工作人员来进行读取,完成后再用ajax将其发送到php导入脚本。

代码语言:javascript
复制
$('#input-excel2').change(function(e){
            var v=Date.now();
            var worker = new Worker("./scripts/parsexlsx2.js?v="+v);
            var data= e.target.files[0];
            var filename= e.target.files[0].name;
            if(filecheck(filename)) {
                worker.postMessage(data);
                $('#loader2').jqxLoader('open');
                worker.onmessage = function(e) {
                    $.ajax({
                            type:"POST",
                            url: "./scripts/import2.php?action=import",
                            data: {data: e.data, datei: filename},
                            datatype: "JSON",
                            success: function(answer) {
                                $('#eventsPanel2').html(answer);
                                $("#input-excel2").val("");
                                getlastuploads();
                            }
                        });
                    worker.terminate();
                    $('#loader2').jqxLoader('close');
                };
            } else {
                $('#eventsPanel2').html("Die Datei "+filename+ " wurde bereits importiert!");
            }
        });

这是工作程序中的实际读取脚本:

代码语言:javascript
复制
importScripts('../js-xlsx/dist/xlsx.full.min.js');
onmessage=function(msg) {

var reader = new FileReader();
reader.readAsArrayBuffer(msg.data);
reader.onerror  = function(e) {
    var htmlstr = e.data;
};
reader.onload = function(e) {
    var data = new Uint8Array(reader.result); //reader.result;
    var wb = XLSX.read(data,{type:'array',cellDates:true, cellNF: false, cellText:false});
    var sheetName = wb.SheetNames[0];
    var result = XLSX.utils.sheet_to_json(wb.Sheets[sheetName],{header:1,dateNF:'YYYY-MM-DD"T"hh:mm:ss'});
    postMessage(result);
};
};    
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-10-29 13:30:11

我自己找到了答案:问题是PHP脚本。PHP在max_input_vars中为POST设置了一个限制。解决方案:在通过POST发送数据之前对数据进行JSON_stringify处理。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53045446

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档