forked from sheetjs/sheetjs
updating to 0.11.3
This commit is contained in:
parent
2fffd43aa8
commit
06bfcf8394
@ -64,9 +64,7 @@ if(typeof Uint8Array !== 'undefined') {
|
|||||||
if(typeof console !== 'undefined') console.log("onload", new Date());
|
if(typeof console !== 'undefined') console.log("onload", new Date());
|
||||||
var arraybuffer = oReq.response;
|
var arraybuffer = oReq.response;
|
||||||
var data = new Uint8Array(arraybuffer);
|
var data = new Uint8Array(arraybuffer);
|
||||||
var arr = new Array();
|
var wb = XLSX.read(data, {type:"array"});
|
||||||
for(var i = 0; i != data.length; ++i) arr[i] = String.fromCharCode(data[i]);
|
|
||||||
var wb = XLSX.read(arr.join(""), {type:"binary"});
|
|
||||||
process_wb(wb);
|
process_wb(wb);
|
||||||
};
|
};
|
||||||
} else {
|
} else {
|
||||||
|
361
index.html
361
index.html
@ -4,7 +4,7 @@
|
|||||||
<html>
|
<html>
|
||||||
<head>
|
<head>
|
||||||
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
|
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
|
||||||
<title>JS-XLSX Live Demo</title>
|
<title>SheetJS Live Demo</title>
|
||||||
<style>
|
<style>
|
||||||
#drop{
|
#drop{
|
||||||
border:2px dashed #bbb;
|
border:2px dashed #bbb;
|
||||||
@ -41,7 +41,6 @@ Output Format: <select name="format" onchange="setfmt()">
|
|||||||
<input type="button" id="dotext" value="Click here to process the base64 text" onclick="b64it();"/><br />
|
<input type="button" id="dotext" value="Click here to process the base64 text" onclick="b64it();"/><br />
|
||||||
<b>Advanced Demo Options:</b>
|
<b>Advanced Demo Options:</b>
|
||||||
Use Web Workers: (when available) <input type="checkbox" name="useworker" checked>
|
Use Web Workers: (when available) <input type="checkbox" name="useworker" checked>
|
||||||
Use Transferrables: (when available) <input type="checkbox" name="xferable" checked>
|
|
||||||
Use readAsBinaryString: (when available) <input type="checkbox" name="userabs" checked>
|
Use readAsBinaryString: (when available) <input type="checkbox" name="userabs" checked>
|
||||||
</pre>
|
</pre>
|
||||||
<pre id="out"></pre>
|
<pre id="out"></pre>
|
||||||
@ -51,252 +50,166 @@ Use readAsBinaryString: (when available) <input type="checkbox" name="userabs" c
|
|||||||
<script src="xlsx.full.min.js"></script>
|
<script src="xlsx.full.min.js"></script>
|
||||||
<script>
|
<script>
|
||||||
/*jshint browser:true */
|
/*jshint browser:true */
|
||||||
|
/* eslint-env browser */
|
||||||
|
/* eslint no-use-before-define:0 */
|
||||||
|
/*global Uint8Array, Uint16Array, ArrayBuffer */
|
||||||
/*global XLSX */
|
/*global XLSX */
|
||||||
var X = XLSX;
|
var X = XLSX;
|
||||||
var XW = {
|
var XW = {
|
||||||
/* worker message */
|
/* worker message */
|
||||||
msg: 'xlsx',
|
msg: 'xlsx',
|
||||||
/* worker scripts */
|
/* worker scripts */
|
||||||
rABS: './xlsxworker2.js',
|
worker: './xlsxworker.js'
|
||||||
norABS: './xlsxworker1.js',
|
|
||||||
noxfer: './xlsxworker.js'
|
|
||||||
};
|
};
|
||||||
|
|
||||||
var rABS = typeof FileReader !== "undefined" && typeof FileReader.prototype !== "undefined" && typeof FileReader.prototype.readAsBinaryString !== "undefined";
|
|
||||||
if(!rABS) {
|
|
||||||
document.getElementsByName("userabs")[0].disabled = true;
|
|
||||||
document.getElementsByName("userabs")[0].checked = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
var use_worker = typeof Worker !== 'undefined';
|
|
||||||
if(!use_worker) {
|
|
||||||
document.getElementsByName("useworker")[0].disabled = true;
|
|
||||||
document.getElementsByName("useworker")[0].checked = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
var transferable = use_worker;
|
|
||||||
if(!transferable) {
|
|
||||||
document.getElementsByName("xferable")[0].disabled = true;
|
|
||||||
document.getElementsByName("xferable")[0].checked = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
var wtf_mode = false;
|
|
||||||
|
|
||||||
function fixdata(data) {
|
|
||||||
var o = "", l = 0, w = 10240;
|
|
||||||
for(; l<data.byteLength/w; ++l) o+=String.fromCharCode.apply(null,new Uint8Array(data.slice(l*w,l*w+w)));
|
|
||||||
o+=String.fromCharCode.apply(null, new Uint8Array(data.slice(l*w)));
|
|
||||||
return o;
|
|
||||||
}
|
|
||||||
|
|
||||||
function ab2str(data) {
|
|
||||||
var o = "", l = 0, w = 10240;
|
|
||||||
for(; l<data.byteLength/w; ++l) o+=String.fromCharCode.apply(null,new Uint16Array(data.slice(l*w,l*w+w)));
|
|
||||||
o+=String.fromCharCode.apply(null, new Uint16Array(data.slice(l*w)));
|
|
||||||
return o;
|
|
||||||
}
|
|
||||||
|
|
||||||
function s2ab(s) {
|
|
||||||
var b = new ArrayBuffer(s.length*2), v = new Uint16Array(b);
|
|
||||||
for (var i=0; i != s.length; ++i) v[i] = s.charCodeAt(i);
|
|
||||||
return [v, b];
|
|
||||||
}
|
|
||||||
|
|
||||||
function xw_noxfer(data, cb) {
|
|
||||||
var worker = new Worker(XW.noxfer);
|
|
||||||
worker.onmessage = function(e) {
|
|
||||||
switch(e.data.t) {
|
|
||||||
case 'ready': break;
|
|
||||||
case 'e': console.error(e.data.d); break;
|
|
||||||
case XW.msg: cb(JSON.parse(e.data.d)); break;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
var arr = rABS ? data : btoa(fixdata(data));
|
|
||||||
worker.postMessage({d:arr,b:rABS});
|
|
||||||
}
|
|
||||||
|
|
||||||
function xw_xfer(data, cb) {
|
|
||||||
var worker = new Worker(rABS ? XW.rABS : XW.norABS);
|
|
||||||
worker.onmessage = function(e) {
|
|
||||||
switch(e.data.t) {
|
|
||||||
case 'ready': break;
|
|
||||||
case 'e': console.error(e.data.d); break;
|
|
||||||
default: xx=ab2str(e.data).replace(/\n/g,"\\n").replace(/\r/g,"\\r"); console.log("done"); cb(JSON.parse(xx)); break;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
if(rABS) {
|
|
||||||
var val = s2ab(data);
|
|
||||||
worker.postMessage(val[1], [val[1]]);
|
|
||||||
} else {
|
|
||||||
worker.postMessage(data, [data]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function xw(data, cb) {
|
|
||||||
transferable = document.getElementsByName("xferable")[0].checked;
|
|
||||||
if(transferable) xw_xfer(data, cb);
|
|
||||||
else xw_noxfer(data, cb);
|
|
||||||
}
|
|
||||||
|
|
||||||
function get_radio_value( radioName ) {
|
|
||||||
var radios = document.getElementsByName( radioName );
|
|
||||||
for( var i = 0; i < radios.length; i++ ) {
|
|
||||||
if( radios[i].checked || radios.length === 1 ) {
|
|
||||||
return radios[i].value;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function to_json(workbook) {
|
|
||||||
var result = {};
|
|
||||||
workbook.SheetNames.forEach(function(sheetName) {
|
|
||||||
var roa = X.utils.sheet_to_row_object_array(workbook.Sheets[sheetName]);
|
|
||||||
if(roa.length > 0){
|
|
||||||
result[sheetName] = roa;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
function to_csv(workbook) {
|
|
||||||
var result = [];
|
|
||||||
workbook.SheetNames.forEach(function(sheetName) {
|
|
||||||
var csv = X.utils.sheet_to_csv(workbook.Sheets[sheetName]);
|
|
||||||
if(csv.length > 0){
|
|
||||||
result.push("SHEET: " + sheetName);
|
|
||||||
result.push("");
|
|
||||||
result.push(csv);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
return result.join("\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
function to_formulae(workbook) {
|
|
||||||
var result = [];
|
|
||||||
workbook.SheetNames.forEach(function(sheetName) {
|
|
||||||
var formulae = X.utils.get_formulae(workbook.Sheets[sheetName]);
|
|
||||||
if(formulae.length > 0){
|
|
||||||
result.push("SHEET: " + sheetName);
|
|
||||||
result.push("");
|
|
||||||
result.push(formulae.join("\n"));
|
|
||||||
}
|
|
||||||
});
|
|
||||||
return result.join("\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
function to_html(workbook) {
|
|
||||||
document.getElementById('htmlout').innerHTML = "";
|
|
||||||
var result = [];
|
|
||||||
workbook.SheetNames.forEach(function(sheetName) {
|
|
||||||
var htmlstr = X.write(workbook, {sheet:sheetName, type:'binary', bookType:'html'});
|
|
||||||
document.getElementById('htmlout').innerHTML += htmlstr;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
var tarea = document.getElementById('b64data');
|
|
||||||
function b64it() {
|
|
||||||
if(typeof console !== 'undefined') console.log("onload", new Date());
|
|
||||||
var wb = X.read(tarea.value, {type: 'base64',WTF:wtf_mode});
|
|
||||||
process_wb(wb);
|
|
||||||
}
|
|
||||||
|
|
||||||
var global_wb;
|
var global_wb;
|
||||||
function process_wb(wb) {
|
|
||||||
global_wb = wb;
|
|
||||||
var output = "";
|
|
||||||
switch(get_radio_value("format")) {
|
|
||||||
case "json":
|
|
||||||
output = JSON.stringify(to_json(wb), 2, 2);
|
|
||||||
break;
|
|
||||||
case "form":
|
|
||||||
output = to_formulae(wb);
|
|
||||||
break;
|
|
||||||
case "html": return to_html(wb);
|
|
||||||
default:
|
|
||||||
output = to_csv(wb);
|
|
||||||
}
|
|
||||||
if(out.innerText === undefined) out.textContent = output;
|
|
||||||
else out.innerText = output;
|
|
||||||
if(typeof console !== 'undefined') console.log("output", new Date());
|
|
||||||
}
|
|
||||||
function setfmt() {if(global_wb) process_wb(global_wb); }
|
|
||||||
|
|
||||||
var drop = document.getElementById('drop');
|
var process_wb = (function() {
|
||||||
function handleDrop(e) {
|
var OUT = document.getElementById('out');
|
||||||
e.stopPropagation();
|
var HTMLOUT = document.getElementById('htmlout');
|
||||||
e.preventDefault();
|
|
||||||
rABS = document.getElementsByName("userabs")[0].checked;
|
var get_format = (function() {
|
||||||
use_worker = document.getElementsByName("useworker")[0].checked;
|
var radios = document.getElementsByName( "format" );
|
||||||
var files = e.dataTransfer.files;
|
return function() {
|
||||||
var f = files[0];
|
for(var i = 0; i < radios.length; ++i) if(radios[i].checked || radios.length === 1) return radios[i].value;
|
||||||
{
|
};
|
||||||
|
})();
|
||||||
|
|
||||||
|
var to_json = function to_json(workbook) {
|
||||||
|
var result = {};
|
||||||
|
workbook.SheetNames.forEach(function(sheetName) {
|
||||||
|
var roa = X.utils.sheet_to_json(workbook.Sheets[sheetName]);
|
||||||
|
if(roa.length) result[sheetName] = roa;
|
||||||
|
});
|
||||||
|
return JSON.stringify(result, 2, 2);
|
||||||
|
};
|
||||||
|
|
||||||
|
var to_csv = function to_csv(workbook) {
|
||||||
|
var result = [];
|
||||||
|
workbook.SheetNames.forEach(function(sheetName) {
|
||||||
|
var csv = X.utils.sheet_to_csv(workbook.Sheets[sheetName]);
|
||||||
|
if(csv.length){
|
||||||
|
result.push("SHEET: " + sheetName);
|
||||||
|
result.push("");
|
||||||
|
result.push(csv);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return result.join("\n");
|
||||||
|
};
|
||||||
|
|
||||||
|
var to_fmla = function to_fmla(workbook) {
|
||||||
|
var result = [];
|
||||||
|
workbook.SheetNames.forEach(function(sheetName) {
|
||||||
|
var formulae = X.utils.get_formulae(workbook.Sheets[sheetName]);
|
||||||
|
if(formulae.length){
|
||||||
|
result.push("SHEET: " + sheetName);
|
||||||
|
result.push("");
|
||||||
|
result.push(formulae.join("\n"));
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return result.join("\n");
|
||||||
|
};
|
||||||
|
|
||||||
|
var to_html = function to_html(workbook) {
|
||||||
|
HTMLOUT.innerHTML = "";
|
||||||
|
workbook.SheetNames.forEach(function(sheetName) {
|
||||||
|
var htmlstr = X.write(workbook, {sheet:sheetName, type:'binary', bookType:'html'});
|
||||||
|
HTMLOUT.innerHTML += htmlstr;
|
||||||
|
});
|
||||||
|
return "";
|
||||||
|
};
|
||||||
|
|
||||||
|
return function process_wb(wb) {
|
||||||
|
global_wb = wb;
|
||||||
|
var output = "";
|
||||||
|
switch(get_format()) {
|
||||||
|
case "form": output = to_fmla(wb); break;
|
||||||
|
case "html": output = to_html(wb); break;
|
||||||
|
case "json": output = to_json(wb); break;
|
||||||
|
default: output = to_csv(wb);
|
||||||
|
}
|
||||||
|
if(OUT.innerText === undefined) OUT.textContent = output;
|
||||||
|
else OUT.innerText = output;
|
||||||
|
if(typeof console !== 'undefined') console.log("output", new Date());
|
||||||
|
};
|
||||||
|
})();
|
||||||
|
|
||||||
|
var setfmt = window.setfmt = function setfmt() { if(global_wb) process_wb(global_wb); };
|
||||||
|
|
||||||
|
var b64it = window.b64it = (function() {
|
||||||
|
var tarea = document.getElementById('b64data');
|
||||||
|
return function b64it() {
|
||||||
|
if(typeof console !== 'undefined') console.log("onload", new Date());
|
||||||
|
var wb = X.read(tarea.value, {type:'base64', WTF:false});
|
||||||
|
process_wb(wb);
|
||||||
|
};
|
||||||
|
})();
|
||||||
|
|
||||||
|
var do_file = (function() {
|
||||||
|
var rABS = typeof FileReader !== "undefined" && (FileReader.prototype||{}).readAsBinaryString;
|
||||||
|
var domrabs = document.getElementsByName("userabs")[0];
|
||||||
|
if(!rABS) domrabs.disabled = !(domrabs.checked = false);
|
||||||
|
|
||||||
|
var use_worker = typeof Worker !== 'undefined';
|
||||||
|
var domwork = document.getElementsByName("useworker")[0];
|
||||||
|
if(!use_worker) domwork.disabled = !(domwork.checked = false);
|
||||||
|
|
||||||
|
var xw = function xw(data, cb) {
|
||||||
|
var worker = new Worker(XW.worker);
|
||||||
|
worker.onmessage = function(e) {
|
||||||
|
switch(e.data.t) {
|
||||||
|
case 'ready': break;
|
||||||
|
case 'e': console.error(e.data.d); break;
|
||||||
|
case XW.msg: cb(JSON.parse(e.data.d)); break;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
worker.postMessage({d:data,b:rABS?'binary':'array'});
|
||||||
|
};
|
||||||
|
|
||||||
|
return function do_file(files) {
|
||||||
|
rABS = domrabs.checked;
|
||||||
|
use_worker = domwork.checked;
|
||||||
|
var f = files[0];
|
||||||
var reader = new FileReader();
|
var reader = new FileReader();
|
||||||
var name = f.name;
|
|
||||||
reader.onload = function(e) {
|
reader.onload = function(e) {
|
||||||
if(typeof console !== 'undefined') console.log("onload", new Date(), rABS, use_worker);
|
if(typeof console !== 'undefined') console.log("onload", new Date(), rABS, use_worker);
|
||||||
var data = e.target.result;
|
var data = e.target.result;
|
||||||
if(use_worker) {
|
if(!rABS) data = new Uint8Array(data);
|
||||||
xw(data, process_wb);
|
if(use_worker) xw(data, process_wb);
|
||||||
} else {
|
else process_wb(X.read(data, {type: rABS ? 'binary' : 'array'}));
|
||||||
var wb;
|
|
||||||
if(rABS) {
|
|
||||||
wb = X.read(data, {type: 'binary'});
|
|
||||||
} else {
|
|
||||||
var arr = fixdata(data);
|
|
||||||
wb = X.read(btoa(arr), {type: 'base64'});
|
|
||||||
}
|
|
||||||
process_wb(wb);
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
if(rABS) reader.readAsBinaryString(f);
|
if(rABS) reader.readAsBinaryString(f);
|
||||||
else reader.readAsArrayBuffer(f);
|
else reader.readAsArrayBuffer(f);
|
||||||
|
};
|
||||||
|
})();
|
||||||
|
|
||||||
|
(function() {
|
||||||
|
var drop = document.getElementById('drop');
|
||||||
|
if(!drop.addEventListener) return;
|
||||||
|
|
||||||
|
function handleDrop(e) {
|
||||||
|
e.stopPropagation();
|
||||||
|
e.preventDefault();
|
||||||
|
do_file(e.dataTransfer.files);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
function handleDragover(e) {
|
function handleDragover(e) {
|
||||||
e.stopPropagation();
|
e.stopPropagation();
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
e.dataTransfer.dropEffect = 'copy';
|
e.dataTransfer.dropEffect = 'copy';
|
||||||
}
|
}
|
||||||
|
|
||||||
if(drop.addEventListener) {
|
|
||||||
drop.addEventListener('dragenter', handleDragover, false);
|
drop.addEventListener('dragenter', handleDragover, false);
|
||||||
drop.addEventListener('dragover', handleDragover, false);
|
drop.addEventListener('dragover', handleDragover, false);
|
||||||
drop.addEventListener('drop', handleDrop, false);
|
drop.addEventListener('drop', handleDrop, false);
|
||||||
}
|
})();
|
||||||
|
|
||||||
|
(function() {
|
||||||
var xlf = document.getElementById('xlf');
|
var xlf = document.getElementById('xlf');
|
||||||
function handleFile(e) {
|
if(!xlf.addEventListener) return;
|
||||||
rABS = document.getElementsByName("userabs")[0].checked;
|
function handleFile(e) { do_file(e.target.files); }
|
||||||
use_worker = document.getElementsByName("useworker")[0].checked;
|
xlf.addEventListener('change', handleFile, false);
|
||||||
var files = e.target.files;
|
})();
|
||||||
var f = files[0];
|
|
||||||
{
|
|
||||||
var reader = new FileReader();
|
|
||||||
var name = f.name;
|
|
||||||
reader.onload = function(e) {
|
|
||||||
if(typeof console !== 'undefined') console.log("onload", new Date(), rABS, use_worker);
|
|
||||||
var data = e.target.result;
|
|
||||||
if(use_worker) {
|
|
||||||
xw(data, process_wb);
|
|
||||||
} else {
|
|
||||||
var wb;
|
|
||||||
if(rABS) {
|
|
||||||
wb = X.read(data, {type: 'binary'});
|
|
||||||
} else {
|
|
||||||
var arr = fixdata(data);
|
|
||||||
wb = X.read(btoa(arr), {type: 'base64'});
|
|
||||||
}
|
|
||||||
process_wb(wb);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
if(rABS) reader.readAsBinaryString(f);
|
|
||||||
else reader.readAsArrayBuffer(f);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if(xlf.addEventListener) xlf.addEventListener('change', handleFile, false);
|
|
||||||
</script>
|
</script>
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
var _gaq = _gaq || [];
|
var _gaq = _gaq || [];
|
||||||
|
@ -1723,6 +1723,39 @@ describe('json output', function() {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
var codes = [["あ 1", "\u00E3\u0081\u0082 1"]]
|
||||||
|
var plaintext_val = [
|
||||||
|
["A1", 'n', -0.08, "-0.08"],
|
||||||
|
["B1", 'n', 4001, "4,001"],
|
||||||
|
["C1", 's', "あ 1", "あ 1"],
|
||||||
|
["A2", 'n', 41.08, "$41.08"],
|
||||||
|
["B2", 'n', 0.11, "11%"],
|
||||||
|
["B3", 'b', true, "TRUE"],
|
||||||
|
["C3", 'b', false, "FALSE"],
|
||||||
|
["A3"]];
|
||||||
|
function plaintext_test(wb, raw, sn) {
|
||||||
|
var sheet = wb.Sheets[sn || wb.SheetNames[0]];
|
||||||
|
plaintext_val.forEach(function(x) {
|
||||||
|
var cell = get_cell(sheet, x[0]);
|
||||||
|
if(x.length == 1) { if(cell) { assert.equal(cell.t, 'z'); assert(!cell.v); } return; }
|
||||||
|
assert.equal(cell.v, x[2+!!raw]); assert.equal(cell.t, raw ? 's' : x[1]);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
function make_html_str(idx) { return ["<table>",
|
||||||
|
"<tr><td>-0.08</td><td>4,001</td><td>", codes[0][idx], "</td></tr>",
|
||||||
|
"<tr><td>$41.08</td><td>11%</td></tr>",
|
||||||
|
"<tr><td></td><td>TRUE</td><td>FALSE</td></tr>",
|
||||||
|
"</table>" ].join(""); }
|
||||||
|
function make_csv_str(idx) { return [ '\u00EF\u00BB\u00BF' +
|
||||||
|
'-0.08,"4,001",' + codes[0][idx] + '',
|
||||||
|
'$41.08,11%',
|
||||||
|
',TRUE,FALSE'
|
||||||
|
].join("\n"); }
|
||||||
|
var html_bstr = make_html_str(1), html_str = make_html_str(0);
|
||||||
|
var csv_bstr = make_csv_str(1);
|
||||||
|
|
||||||
|
|
||||||
describe('csv', function() {
|
describe('csv', function() {
|
||||||
describe('input', function(){
|
describe('input', function(){
|
||||||
var b = "1,2,3,\nTRUE,FALSE,,sheetjs\nfoo,bar,2/19/14,0.3\n,,,\nbaz,,qux,\n";
|
var b = "1,2,3,\nTRUE,FALSE,,sheetjs\nfoo,bar,2/19/14,0.3\n,,,\nbaz,,qux,\n";
|
||||||
@ -1769,6 +1802,17 @@ describe('csv', function() {
|
|||||||
assert.equal(cell.v.getMonth(), 2);
|
assert.equal(cell.v.getMonth(), 2);
|
||||||
assert.equal(cell.w, "2/3/14");
|
assert.equal(cell.w, "2/3/14");
|
||||||
});
|
});
|
||||||
|
it('should interpret values by default', function() { plaintext_test(X.read(csv_bstr, {type:"binary"}), false); });
|
||||||
|
it('should generate strings if raw option is passed', function() { plaintext_test(X.read(csv_bstr, {type:"binary", raw:true}), true); });
|
||||||
|
it('should handle formulae', function() {
|
||||||
|
var bb = '=,=1+1,="100"';
|
||||||
|
var sheet = X.read(bb, {type:"binary"}).Sheets.Sheet1;
|
||||||
|
assert.equal(get_cell(sheet, "A1").t, 's');
|
||||||
|
assert.equal(get_cell(sheet, "A1").v, '=');
|
||||||
|
assert.equal(get_cell(sheet, "B1").f, '1+1');
|
||||||
|
assert.equal(get_cell(sheet, "C1").t, 's');
|
||||||
|
assert.equal(get_cell(sheet, "C1").v, '100');
|
||||||
|
});
|
||||||
});
|
});
|
||||||
describe('output', function(){
|
describe('output', function(){
|
||||||
var data, ws;
|
var data, ws;
|
||||||
@ -1845,37 +1889,26 @@ describe('csv', function() {
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
var JSDOM = null;
|
||||||
|
var domtest = browser || (function(){try{return !!(JSDOM=require('jsdom').JSDOM);}catch(e){return 0;}})();
|
||||||
|
|
||||||
|
function get_dom_element(html) {
|
||||||
|
if(browser) {
|
||||||
|
var domelt = document.createElement('div');
|
||||||
|
domelt.innerHTML = html;
|
||||||
|
return domelt;
|
||||||
|
}
|
||||||
|
return new JSDOM(html).window.document.body.children[0];
|
||||||
|
}
|
||||||
|
|
||||||
describe('HTML', function() {
|
describe('HTML', function() {
|
||||||
describe('input', function(){
|
describe('input string', function(){
|
||||||
var b = "<table><tr><td>-0.08</td><td>4,001</td><td>\u00e3\u0081\u0082 1</td></tr><tr><td>$41.08</td><td>11%</td></tr></table>";
|
it('should interpret values by default', function() { plaintext_test(X.read(html_bstr, {type:"binary"}), false); });
|
||||||
it('should generate numbers by default', function() {
|
it('should generate strings if raw option is passed', function() { plaintext_test(X.read(html_bstr, {type:"binary", raw:true}), true); });
|
||||||
var sheet = X.read(b, {type:"binary"}).Sheets.Sheet1;
|
});
|
||||||
var cell = get_cell(sheet, "A1");
|
(domtest ? describe : describe.skip)('input DOM', function() {
|
||||||
assert.equal(cell.v, -0.08);
|
it('should interpret values by default', function() { plaintext_test(X.utils.table_to_book(get_dom_element(html_str)), false); });
|
||||||
assert.equal(cell.t, 'n');
|
it('should generate strings if raw option is passed', function() { plaintext_test(X.utils.table_to_book(get_dom_element(html_str), {raw:true}), true); });
|
||||||
cell = get_cell(sheet, "B1");
|
|
||||||
assert.equal(cell.v, 4001);
|
|
||||||
cell = get_cell(sheet, "C1");
|
|
||||||
assert.equal(cell.v, "あ 1");
|
|
||||||
cell = get_cell(sheet, "A2");
|
|
||||||
assert.equal(cell.v, 41.08);
|
|
||||||
cell = get_cell(sheet, "B2");
|
|
||||||
assert.equal(cell.v, .11);
|
|
||||||
});
|
|
||||||
it('should generate strings if raw option is passed', function() {
|
|
||||||
var sheet = X.read(b, {type:"binary", raw:true}).Sheets.Sheet1;
|
|
||||||
var cell = get_cell(sheet, "A1");
|
|
||||||
assert.equal(cell.v, "-0.08");
|
|
||||||
assert.equal(cell.t, 's');
|
|
||||||
cell = get_cell(sheet, "B1");
|
|
||||||
assert.equal(cell.v, "4,001");
|
|
||||||
cell = get_cell(sheet, "C1");
|
|
||||||
assert.equal(cell.v, "あ 1");
|
|
||||||
cell = get_cell(sheet, "A2");
|
|
||||||
assert.equal(cell.v, "$41.08");
|
|
||||||
cell = get_cell(sheet, "B2");
|
|
||||||
assert.equal(cell.v, "11%");
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -46,13 +46,13 @@
|
|||||||
<script src="mocha.js"></script>
|
<script src="mocha.js"></script>
|
||||||
<script>
|
<script>
|
||||||
window.initMochaPhantomJS && window.initMochaPhantomJS();
|
window.initMochaPhantomJS && window.initMochaPhantomJS();
|
||||||
mocha.setup('bdd');
|
mocha.setup({ui:'bdd', timeout:15000});
|
||||||
</script>
|
</script>
|
||||||
<script src="core.js"></script>
|
<script src="core.js"></script>
|
||||||
<script>
|
<script>
|
||||||
if(typeof mochaSaucePlease !== "undefined") mochaSaucePlease();
|
if(typeof mochaSaucePlease !== "undefined") mochaSaucePlease();
|
||||||
else if(window.mochaPhantomJS) mochaPhantomJS.run();
|
else if(window.mochaPhantomJS) mochaPhantomJS.run();
|
||||||
else mocha.run();
|
else typeof mocha_sauce !== 'undefined' ? mocha_sauce() : mocha.run();
|
||||||
</script>
|
</script>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
26
xlsx.core.min.js
vendored
26
xlsx.core.min.js
vendored
File diff suppressed because one or more lines are too long
28
xlsx.full.min.js
vendored
28
xlsx.full.min.js
vendored
File diff suppressed because one or more lines are too long
181
xlsx.js
181
xlsx.js
@ -6,7 +6,7 @@
|
|||||||
/*global global, exports, module, require:false, process:false, Buffer:false */
|
/*global global, exports, module, require:false, process:false, Buffer:false */
|
||||||
var XLSX = {};
|
var XLSX = {};
|
||||||
(function make_xlsx(XLSX){
|
(function make_xlsx(XLSX){
|
||||||
XLSX.version = '0.11.2';
|
XLSX.version = '0.11.3';
|
||||||
var current_codepage = 1200;
|
var current_codepage = 1200;
|
||||||
/*global cptable:true */
|
/*global cptable:true */
|
||||||
if(typeof module !== "undefined" && typeof require !== 'undefined') {
|
if(typeof module !== "undefined" && typeof require !== 'undefined') {
|
||||||
@ -1537,8 +1537,8 @@ function fuzzydate(s) {
|
|||||||
if(y < 0 || y > 8099) return n;
|
if(y < 0 || y > 8099) return n;
|
||||||
if((m > 0 || d > 1) && y != 101) return o;
|
if((m > 0 || d > 1) && y != 101) return o;
|
||||||
if(s.toLowerCase().match(/jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec/)) return o;
|
if(s.toLowerCase().match(/jan|feb|mar|apr|may|jun|jul|aug|sep|oct|nov|dec/)) return o;
|
||||||
if(s.match(/[^-0-9:,\/\\]/)) return o;
|
if(s.match(/[^-0-9:,\/\\]/)) return n;
|
||||||
return n;
|
return o;
|
||||||
}
|
}
|
||||||
|
|
||||||
var safe_split_regex = "abacaba".split(/(:?b)/i).length == 5;
|
var safe_split_regex = "abacaba".split(/(:?b)/i).length == 5;
|
||||||
@ -1857,8 +1857,8 @@ var __toBuffer, ___toBuffer;
|
|||||||
__toBuffer = ___toBuffer = function toBuffer_(bufs) { var x = []; for(var i = 0; i < bufs[0].length; ++i) { x.push.apply(x, bufs[0][i]); } return x; };
|
__toBuffer = ___toBuffer = function toBuffer_(bufs) { var x = []; for(var i = 0; i < bufs[0].length; ++i) { x.push.apply(x, bufs[0][i]); } return x; };
|
||||||
var __utf16le, ___utf16le;
|
var __utf16le, ___utf16le;
|
||||||
__utf16le = ___utf16le = function utf16le_(b,s,e) { var ss=[]; for(var i=s; i<e; i+=2) ss.push(String.fromCharCode(__readUInt16LE(b,i))); return ss.join(""); };
|
__utf16le = ___utf16le = function utf16le_(b,s,e) { var ss=[]; for(var i=s; i<e; i+=2) ss.push(String.fromCharCode(__readUInt16LE(b,i))); return ss.join(""); };
|
||||||
var __hexlify, ___hexlify;
|
var __hexlify = function(b,s,l) { var ss=[]; for(var i=s; i<s+l; ++i) ss.push(("0" + b[i].toString(16)).slice(-2)); return ss.join(""); };
|
||||||
__hexlify = ___hexlify = function hexlify_(b,s,l) { return b.slice(s,(s+l)).map(function(x){return (x<16?"0":"") + x.toString(16);}).join(""); };
|
var ___hexlify = __hexlify;
|
||||||
var __utf8, ___utf8;
|
var __utf8, ___utf8;
|
||||||
__utf8 = ___utf8 = function(b,s,e) { var ss=[]; for(var i=s; i<e; i++) ss.push(String.fromCharCode(__readUInt8(b,i))); return ss.join(""); };
|
__utf8 = ___utf8 = function(b,s,e) { var ss=[]; for(var i=s; i<e; i++) ss.push(String.fromCharCode(__readUInt8(b,i))); return ss.join(""); };
|
||||||
var __lpstr, ___lpstr;
|
var __lpstr, ___lpstr;
|
||||||
@ -5712,6 +5712,16 @@ var PRN = (function() {
|
|||||||
return arr;
|
return arr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function guess_sep(str) {
|
||||||
|
var cnt = [], instr = false, end = 0, cc = 0;
|
||||||
|
for(;end < str.length;++end) {
|
||||||
|
if((cc=str.charCodeAt(end)) == 0x22) instr = !instr;
|
||||||
|
else if(!instr) cnt[cc] = (cnt[cc]||0)+1;
|
||||||
|
}
|
||||||
|
if((cnt[0x2C]||0) >= (cnt[0x09]||0)) return ",";
|
||||||
|
return "\t";
|
||||||
|
}
|
||||||
|
|
||||||
function dsv_to_sheet_str(str, opts) {
|
function dsv_to_sheet_str(str, opts) {
|
||||||
var o = opts || {};
|
var o = opts || {};
|
||||||
var sep = "";
|
var sep = "";
|
||||||
@ -5719,9 +5729,8 @@ var PRN = (function() {
|
|||||||
var ws = o.dense ? ([]) : ({});
|
var ws = o.dense ? ([]) : ({});
|
||||||
var range = ({s: {c:0, r:0}, e: {c:0, r:0}});
|
var range = ({s: {c:0, r:0}, e: {c:0, r:0}});
|
||||||
|
|
||||||
/* known sep */
|
|
||||||
if(str.substr(0,4) == "sep=" && str.charCodeAt(5) == 10) { sep = str.charAt(4); str = str.substr(6); }
|
if(str.substr(0,4) == "sep=" && str.charCodeAt(5) == 10) { sep = str.charAt(4); str = str.substr(6); }
|
||||||
else if(str.substr(0,1024).indexOf("\t") == -1) sep = ","; else sep = "\t";
|
else sep = guess_sep(str.substr(0,1024));
|
||||||
var R = 0, C = 0, v = 0;
|
var R = 0, C = 0, v = 0;
|
||||||
var start = 0, end = 0, sepcc = sep.charCodeAt(0), instr = false, cc=0;
|
var start = 0, end = 0, sepcc = sep.charCodeAt(0), instr = false, cc=0;
|
||||||
str = str.replace(/\r\n/mg, "\n");
|
str = str.replace(/\r\n/mg, "\n");
|
||||||
@ -5729,24 +5738,30 @@ var PRN = (function() {
|
|||||||
function finish_cell() {
|
function finish_cell() {
|
||||||
var s = str.slice(start, end);
|
var s = str.slice(start, end);
|
||||||
var cell = ({});
|
var cell = ({});
|
||||||
if(o.raw) { cell.t = 's'; cell.v = s; }
|
if(s.charAt(0) == '"' && s.charAt(s.length - 1) == '"') s = s.slice(1,-1).replace(/""/g,'"');
|
||||||
else if(s.charCodeAt(0) == 0x3D) { cell.t = 'n'; cell.f = s.substr(1); }
|
if(s.length == 0) cell.t = 'z';
|
||||||
|
else if(o.raw) { cell.t = 's'; cell.v = s; }
|
||||||
|
else if(s.charCodeAt(0) == 0x3D) {
|
||||||
|
if(s.charCodeAt(1) == 0x22 && s.charCodeAt(s.length - 1) == 0x22) { cell.t = 's'; cell.v = s.slice(2,-1).replace(/""/g,'"'); }
|
||||||
|
else if(fuzzyfmla(s)) { cell.t = 'n'; cell.f = s.substr(1); }
|
||||||
|
else { cell.t = 's'; cell.v = s; } }
|
||||||
else if(s == "TRUE") { cell.t = 'b'; cell.v = true; }
|
else if(s == "TRUE") { cell.t = 'b'; cell.v = true; }
|
||||||
else if(s == "FALSE") { cell.t = 'b'; cell.v = false; }
|
else if(s == "FALSE") { cell.t = 'b'; cell.v = false; }
|
||||||
else if(!isNaN(v = fuzzynum(s))) { cell.t = 'n'; cell.w = s; cell.v = v; }
|
else if(!isNaN(v = fuzzynum(s))) { cell.t = 'n'; if(o.cellText !== false) cell.w = s; cell.v = v; }
|
||||||
else if(!isNaN(fuzzydate(s).getDate()) || _re && s.match(_re)) {
|
else if(!isNaN(fuzzydate(s).getDate()) || _re && s.match(_re)) {
|
||||||
cell.z = o.dateNF || SSF._table[14];
|
cell.z = o.dateNF || SSF._table[14];
|
||||||
var k = 0;
|
var k = 0;
|
||||||
if(_re && s.match(_re)){ s=dateNF_fix(s, o.dateNF, (s.match(_re)||[])); k=1; }
|
if(_re && s.match(_re)){ s=dateNF_fix(s, o.dateNF, (s.match(_re)||[])); k=1; }
|
||||||
if(o.cellDates) { cell.t = 'd'; cell.v = parseDate(s, k); }
|
if(o.cellDates) { cell.t = 'd'; cell.v = parseDate(s, k); }
|
||||||
else { cell.t = 'n'; cell.v = datenum(parseDate(s, k)); }
|
else { cell.t = 'n'; cell.v = datenum(parseDate(s, k)); }
|
||||||
cell.w = SSF.format(cell.z, cell.v instanceof Date ? datenum(cell.v):cell.v);
|
if(o.cellText !== false) cell.w = SSF.format(cell.z, cell.v instanceof Date ? datenum(cell.v):cell.v);
|
||||||
|
if(!o.cellNF) delete cell.z;
|
||||||
} else {
|
} else {
|
||||||
cell.t = 's';
|
cell.t = 's';
|
||||||
if(s.charAt(0) == '"' && s.charAt(s.length - 1) == '"') s = s.slice(1,-1).replace(/""/g,'"');
|
|
||||||
cell.v = s;
|
cell.v = s;
|
||||||
}
|
}
|
||||||
if(o.dense) { if(!ws[R]) ws[R] = []; ws[R][C] = cell; }
|
if(cell.t == 'z'){}
|
||||||
|
else if(o.dense) { if(!ws[R]) ws[R] = []; ws[R][C] = cell; }
|
||||||
else ws[encode_cell({c:C,r:R})] = cell;
|
else ws[encode_cell({c:C,r:R})] = cell;
|
||||||
start = end+1;
|
start = end+1;
|
||||||
if(range.e.c < C) range.e.c = C;
|
if(range.e.c < C) range.e.c = C;
|
||||||
@ -5779,7 +5794,7 @@ var PRN = (function() {
|
|||||||
case 'array': str = cc2str(d); break;
|
case 'array': str = cc2str(d); break;
|
||||||
default: throw new Error("Unrecognized type " + opts.type);
|
default: throw new Error("Unrecognized type " + opts.type);
|
||||||
}
|
}
|
||||||
if(bytes[0] == 0xEF && bytes[1] == 0xBB && bytes[2] == 0xBF) str = utf8read(str);
|
if(bytes[0] == 0xEF && bytes[1] == 0xBB && bytes[2] == 0xBF) str = utf8read(str.slice(3));
|
||||||
return prn_to_sheet_str(str, opts);
|
return prn_to_sheet_str(str, opts);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -8017,7 +8032,7 @@ function update_xfext(xf, xfext) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* 18.6 Calculation Chain */
|
/* 18.6 Calculation Chain */
|
||||||
function parse_cc_xml(data, opts) {
|
function parse_cc_xml(data, name, opts) {
|
||||||
var d = [];
|
var d = [];
|
||||||
if(!data) return d;
|
if(!data) return d;
|
||||||
var l = 0, i = 1;
|
var l = 0, i = 1;
|
||||||
@ -8035,6 +8050,7 @@ function parse_cc_xml(data, opts) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function write_cc_xml(data, opts) { }
|
function write_cc_xml(data, opts) { }
|
||||||
|
|
||||||
/* [MS-XLSB] 2.6.4.1 */
|
/* [MS-XLSB] 2.6.4.1 */
|
||||||
function parse_BrtCalcChainItem$(data, length) {
|
function parse_BrtCalcChainItem$(data, length) {
|
||||||
var out = {};
|
var out = {};
|
||||||
@ -8050,7 +8066,7 @@ function parse_BrtCalcChainItem$(data, length) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* 18.6 Calculation Chain */
|
/* 18.6 Calculation Chain */
|
||||||
function parse_cc_bin(data, opts) {
|
function parse_cc_bin(data, name, opts) {
|
||||||
var out = [];
|
var out = [];
|
||||||
var pass = false;
|
var pass = false;
|
||||||
recordhopper(data, function hopper_cc(val, R_n, RT) {
|
recordhopper(data, function hopper_cc(val, R_n, RT) {
|
||||||
@ -8068,6 +8084,57 @@ function parse_cc_bin(data, opts) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function write_cc_bin(data, opts) { }
|
function write_cc_bin(data, opts) { }
|
||||||
|
/* 18.14 Supplementary Workbook Data */
|
||||||
|
function parse_xlink_xml(data, name, _opts) {
|
||||||
|
var opts = _opts || {};
|
||||||
|
//if(opts.WTF) throw "XLSX External Link";
|
||||||
|
}
|
||||||
|
|
||||||
|
/* [MS-XLSB] 2.1.7.25 External Link */
|
||||||
|
function parse_xlink_bin(data, name, _opts) {
|
||||||
|
if(!data) return data;
|
||||||
|
var opts = _opts || {};
|
||||||
|
|
||||||
|
var pass = false, end = false;
|
||||||
|
|
||||||
|
recordhopper(data, function xlink_parse(val, R_n, RT) {
|
||||||
|
if(end) return;
|
||||||
|
switch(RT) {
|
||||||
|
case 0x0167: /* 'BrtSupTabs' */
|
||||||
|
case 0x016B: /* 'BrtExternTableStart' */
|
||||||
|
case 0x016C: /* 'BrtExternTableEnd' */
|
||||||
|
case 0x016E: /* 'BrtExternRowHdr' */
|
||||||
|
case 0x016F: /* 'BrtExternCellBlank' */
|
||||||
|
case 0x0170: /* 'BrtExternCellReal' */
|
||||||
|
case 0x0171: /* 'BrtExternCellBool' */
|
||||||
|
case 0x0172: /* 'BrtExternCellError' */
|
||||||
|
case 0x0173: /* 'BrtExternCellString' */
|
||||||
|
case 0x01D8: /* 'BrtExternValueMeta' */
|
||||||
|
case 0x0241: /* 'BrtSupNameStart' */
|
||||||
|
case 0x0242: /* 'BrtSupNameValueStart' */
|
||||||
|
case 0x0243: /* 'BrtSupNameValueEnd' */
|
||||||
|
case 0x0244: /* 'BrtSupNameNum' */
|
||||||
|
case 0x0245: /* 'BrtSupNameErr' */
|
||||||
|
case 0x0246: /* 'BrtSupNameSt' */
|
||||||
|
case 0x0247: /* 'BrtSupNameNil' */
|
||||||
|
case 0x0248: /* 'BrtSupNameBool' */
|
||||||
|
case 0x0249: /* 'BrtSupNameFmla' */
|
||||||
|
case 0x024A: /* 'BrtSupNameBits' */
|
||||||
|
case 0x024B: /* 'BrtSupNameEnd' */
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 0x0023: /* 'BrtFRTBegin' */
|
||||||
|
pass = true; break;
|
||||||
|
case 0x0024: /* 'BrtFRTEnd' */
|
||||||
|
pass = false; break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
if((R_n||"").indexOf("Begin") > 0){/* empty */}
|
||||||
|
else if((R_n||"").indexOf("End") > 0){/* empty */}
|
||||||
|
else if(!pass || opts.WTF) throw new Error("Unexpected record " + RT.toString(16) + " " + R_n);
|
||||||
|
}
|
||||||
|
}, opts);
|
||||||
|
}
|
||||||
RELS.IMG = "http://schemas.openxmlformats.org/officeDocument/2006/relationships/image";
|
RELS.IMG = "http://schemas.openxmlformats.org/officeDocument/2006/relationships/image";
|
||||||
RELS.DRAW = "http://schemas.openxmlformats.org/officeDocument/2006/relationships/drawing";
|
RELS.DRAW = "http://schemas.openxmlformats.org/officeDocument/2006/relationships/drawing";
|
||||||
/* 20.5 DrawingML - SpreadsheetML Drawing */
|
/* 20.5 DrawingML - SpreadsheetML Drawing */
|
||||||
@ -8389,6 +8456,12 @@ function shift_formula_xlsx(f, range, cell) {
|
|||||||
var delta = {r:c.r - s.r, c:c.c - s.c};
|
var delta = {r:c.r - s.r, c:c.c - s.c};
|
||||||
return shift_formula_str(f, delta);
|
return shift_formula_str(f, delta);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* TODO: parse formula */
|
||||||
|
function fuzzyfmla(f) {
|
||||||
|
if(f.length == 1) return false;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
/* --- formula references point to MS-XLS --- */
|
/* --- formula references point to MS-XLS --- */
|
||||||
/* Small helpers */
|
/* Small helpers */
|
||||||
function parseread(l) { return function(blob, length) { blob.l+=l; return; }; }
|
function parseread(l) { return function(blob, length) { blob.l+=l; return; }; }
|
||||||
@ -9213,7 +9286,7 @@ function stringify_formula(formula/*Array<any>*/, range, cell, supbooks, opts) {
|
|||||||
case 'PtgArea3d': /* 2.5.198.28 TODO */
|
case 'PtgArea3d': /* 2.5.198.28 TODO */
|
||||||
type = f[1][0]; ixti = f[1][1]; r = f[1][2];
|
type = f[1][0]; ixti = f[1][1]; r = f[1][2];
|
||||||
sname = (supbooks && supbooks[1] ? supbooks[1][ixti+1] : "**MISSING**");
|
sname = (supbooks && supbooks[1] ? supbooks[1][ixti+1] : "**MISSING**");
|
||||||
stack.push(sname + "!" + encode_range((r)));
|
stack.push(sname + "!" + encode_range_xls((r), opts));
|
||||||
break;
|
break;
|
||||||
case 'PtgAttrSum': /* 2.5.198.41 */
|
case 'PtgAttrSum': /* 2.5.198.41 */
|
||||||
stack.push("SUM(" + stack.pop() + ")");
|
stack.push("SUM(" + stack.pop() + ")");
|
||||||
@ -12952,8 +13025,13 @@ function parse_cmnt(data, name, opts) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function parse_cc(data, name, opts) {
|
function parse_cc(data, name, opts) {
|
||||||
if(name.slice(-4)===".bin") return parse_cc_bin((data), opts);
|
if(name.slice(-4)===".bin") return parse_cc_bin((data), name, opts);
|
||||||
return parse_cc_xml((data), opts);
|
return parse_cc_xml((data), name, opts);
|
||||||
|
}
|
||||||
|
|
||||||
|
function parse_xlink(data, name, opts) {
|
||||||
|
if(name.slice(-4)===".bin") return parse_xlink_bin((data), name, opts);
|
||||||
|
return parse_xlink_xml((data), name, opts);
|
||||||
}
|
}
|
||||||
|
|
||||||
function write_wb(wb, name, opts) {
|
function write_wb(wb, name, opts) {
|
||||||
@ -13360,6 +13438,7 @@ Workbook.Names.push(_DefinedName);
|
|||||||
case 'ContentStatus':
|
case 'ContentStatus':
|
||||||
case 'Identifier':
|
case 'Identifier':
|
||||||
case 'Language':
|
case 'Language':
|
||||||
|
case 'AppName':
|
||||||
if(Rn[0].slice(-2) === "/>") break;
|
if(Rn[0].slice(-2) === "/>") break;
|
||||||
else if(Rn[1]==="/") xlml_set_prop(Props, Rn[3], str.slice(pidx, Rn.index));
|
else if(Rn[1]==="/") xlml_set_prop(Props, Rn[3], str.slice(pidx, Rn.index));
|
||||||
else pidx = Rn.index + Rn[0].length;
|
else pidx = Rn.index + Rn[0].length;
|
||||||
@ -13799,7 +13878,10 @@ Workbook.WBProps.date1904 = true;
|
|||||||
return out;
|
return out;
|
||||||
}
|
}
|
||||||
|
|
||||||
function arr2str(data) { return data.map(_chr).join(""); }
|
function arr2str(data) {
|
||||||
|
if(Array.isArray(data)) return data.map(_chr).join("");
|
||||||
|
var o = []; for(var i = 0; i < data.length; ++i) o[i] = _chr(data[i]); return o.join("");
|
||||||
|
}
|
||||||
|
|
||||||
function parse_xlml(data, opts) {
|
function parse_xlml(data, opts) {
|
||||||
fix_read_opts(opts=opts||{});
|
fix_read_opts(opts=opts||{});
|
||||||
@ -14200,6 +14282,7 @@ function parse_workbook(blob, options) {
|
|||||||
if(file_depth > 1) return;
|
if(file_depth > 1) return;
|
||||||
if(!cell_valid) return;
|
if(!cell_valid) return;
|
||||||
if(options.cellStyles && line.XF && line.XF.data) process_cell_style(cell, line, options);
|
if(options.cellStyles && line.XF && line.XF.data) process_cell_style(cell, line, options);
|
||||||
|
delete line.ixfe; delete line.XF;
|
||||||
lastcell = cell;
|
lastcell = cell;
|
||||||
last_cell = encode_cell(cell);
|
last_cell = encode_cell(cell);
|
||||||
if(range.s) {
|
if(range.s) {
|
||||||
@ -14308,8 +14391,11 @@ wb.opts.Date1904 = Workbook.WBProps.date1904 = val; break;
|
|||||||
case 'FileSharing': break; //TODO
|
case 'FileSharing': break; //TODO
|
||||||
case 'CodePage':
|
case 'CodePage':
|
||||||
/* overrides based on test cases */
|
/* overrides based on test cases */
|
||||||
if(val === 0x5212) val = 1200;
|
switch(val) {
|
||||||
else if(val === 0x8001) val = 1252;
|
case 0x5212: val = 1200; break;
|
||||||
|
case 0x8000: val = 10000; break;
|
||||||
|
case 0x8001: val = 1252; break;
|
||||||
|
}
|
||||||
opts.codepage = val;
|
opts.codepage = val;
|
||||||
set_cp(val);
|
set_cp(val);
|
||||||
break;
|
break;
|
||||||
@ -14897,6 +14983,12 @@ if(cfb.FullPaths) {
|
|||||||
Summary = CFB.find(cfb, '!SummaryInformation');
|
Summary = CFB.find(cfb, '!SummaryInformation');
|
||||||
WB = CFB.find(cfb, '/Workbook');
|
WB = CFB.find(cfb, '/Workbook');
|
||||||
} else {
|
} else {
|
||||||
|
switch(options.type) {
|
||||||
|
case 'base64': cfb = s2a(Base64.decode(cfb)); break;
|
||||||
|
case 'binary': cfb = s2a(cfb); break;
|
||||||
|
case 'buffer': break;
|
||||||
|
case 'array': if(!Array.isArray(cfb)) cfb = Array.prototype.slice.call(cfb); break;
|
||||||
|
}
|
||||||
prep_blob(cfb, 0);
|
prep_blob(cfb, 0);
|
||||||
WB = ({content: cfb});
|
WB = ({content: cfb});
|
||||||
}
|
}
|
||||||
@ -16326,13 +16418,19 @@ var HTML_ = (function() {
|
|||||||
if(range.e.c < C) range.e.c = C;
|
if(range.e.c < C) range.e.c = C;
|
||||||
if(opts.dense) {
|
if(opts.dense) {
|
||||||
if(!ws[R]) ws[R] = [];
|
if(!ws[R]) ws[R] = [];
|
||||||
if(opts.raw) ws[R][C] = {t:'s', v:m};
|
if(!m.length){}
|
||||||
|
else if(opts.raw) ws[R][C] = {t:'s', v:m};
|
||||||
|
else if(m === 'TRUE') ws[R][C] = {t:'b', v:true};
|
||||||
|
else if(m === 'FALSE') ws[R][C] = {t:'b', v:false};
|
||||||
else if(!isNaN(fuzzynum(m))) ws[R][C] = {t:'n', v:fuzzynum(m)};
|
else if(!isNaN(fuzzynum(m))) ws[R][C] = {t:'n', v:fuzzynum(m)};
|
||||||
else ws[R][C] = {t:'s', v:m};
|
else ws[R][C] = {t:'s', v:m};
|
||||||
} else {
|
} else {
|
||||||
var coord = encode_cell({r:R, c:C});
|
var coord = encode_cell({r:R, c:C});
|
||||||
/* TODO: value parsing */
|
/* TODO: value parsing */
|
||||||
if(opts.raw) ws[coord] = {t:'s', v:m};
|
if(!m.length){}
|
||||||
|
else if(opts.raw) ws[coord] = {t:'s', v:m};
|
||||||
|
else if(m === 'TRUE') ws[coord] = {t:'b', v:true};
|
||||||
|
else if(m === 'FALSE') ws[coord] = {t:'b', v:false};
|
||||||
else if(!isNaN(fuzzynum(m))) ws[coord] = {t:'n', v:fuzzynum(m)};
|
else if(!isNaN(fuzzynum(m))) ws[coord] = {t:'n', v:fuzzynum(m)};
|
||||||
else ws[coord] = {t:'s', v:m};
|
else ws[coord] = {t:'s', v:m};
|
||||||
}
|
}
|
||||||
@ -16415,7 +16513,7 @@ function parse_dom_table(table, _opts) {
|
|||||||
var row = rows[R];
|
var row = rows[R];
|
||||||
var elts = row.children;
|
var elts = row.children;
|
||||||
for(_C = C = 0; _C < elts.length; ++_C) {
|
for(_C = C = 0; _C < elts.length; ++_C) {
|
||||||
var elt = elts[_C], v = elts[_C].innerText || elts[_C].textContent;
|
var elt = elts[_C], v = elts[_C].innerText || elts[_C].textContent || "";
|
||||||
for(midx = 0; midx < merges.length; ++midx) {
|
for(midx = 0; midx < merges.length; ++midx) {
|
||||||
var m = merges[midx];
|
var m = merges[midx];
|
||||||
if(m.s.c == C && m.s.r <= R && R <= m.e.r) { C = m.e.c+1; midx = -1; }
|
if(m.s.c == C && m.s.r <= R && R <= m.e.r) { C = m.e.c+1; midx = -1; }
|
||||||
@ -16424,8 +16522,11 @@ function parse_dom_table(table, _opts) {
|
|||||||
CS = +elt.getAttribute("colspan") || 1;
|
CS = +elt.getAttribute("colspan") || 1;
|
||||||
if((RS = +elt.getAttribute("rowspan"))>0 || CS>1) merges.push({s:{r:R,c:C},e:{r:R + (RS||1) - 1, c:C + CS - 1}});
|
if((RS = +elt.getAttribute("rowspan"))>0 || CS>1) merges.push({s:{r:R,c:C},e:{r:R + (RS||1) - 1, c:C + CS - 1}});
|
||||||
var o = {t:'s', v:v};
|
var o = {t:'s', v:v};
|
||||||
if(v != null && v.length) {
|
if(v != null) {
|
||||||
if(opts.raw) o = {t:'s', v:v};
|
if(v.length == 0) o.t = 'z';
|
||||||
|
else if(opts.raw){}
|
||||||
|
else if(v === 'TRUE') o = {t:'b', v:true};
|
||||||
|
else if(v === 'FALSE') o = {t:'b', v:false};
|
||||||
else if(!isNaN(fuzzynum(v))) o = {t:'n', v:fuzzynum(v)};
|
else if(!isNaN(fuzzynum(v))) o = {t:'n', v:fuzzynum(v)};
|
||||||
else if(!isNaN(fuzzydate(v).getDate())) {
|
else if(!isNaN(fuzzydate(v).getDate())) {
|
||||||
o = ({t:'d', v:parseDate(v)});
|
o = ({t:'d', v:parseDate(v)});
|
||||||
@ -17215,6 +17316,8 @@ function safe_parse_sheet(zip, path, relsPath, sheet, sheetRels, sheets, stype,
|
|||||||
}
|
}
|
||||||
|
|
||||||
var nodirs = function nodirs(x){return x.slice(-1) != '/';};
|
var nodirs = function nodirs(x){return x.slice(-1) != '/';};
|
||||||
|
function strip_front_slash(x) { return x.charAt(0) == '/' ? x.slice(1) : x; }
|
||||||
|
|
||||||
function parse_zip(zip, opts) {
|
function parse_zip(zip, opts) {
|
||||||
make_ssf(SSF);
|
make_ssf(SSF);
|
||||||
opts = opts || {};
|
opts = opts || {};
|
||||||
@ -17247,22 +17350,26 @@ function parse_zip(zip, opts) {
|
|||||||
var styles = ({});
|
var styles = ({});
|
||||||
if(!opts.bookSheets && !opts.bookProps) {
|
if(!opts.bookSheets && !opts.bookProps) {
|
||||||
strs = [];
|
strs = [];
|
||||||
if(dir.sst) strs=parse_sst(getzipdata(zip, dir.sst.replace(/^\//,'')), dir.sst, opts);
|
if(dir.sst) strs=parse_sst(getzipdata(zip, strip_front_slash(dir.sst)), dir.sst, opts);
|
||||||
|
|
||||||
if(opts.cellStyles && dir.themes.length) themes = parse_theme(getzipstr(zip, dir.themes[0].replace(/^\//,''), true)||"",dir.themes[0], opts);
|
if(opts.cellStyles && dir.themes.length) themes = parse_theme(getzipstr(zip, dir.themes[0].replace(/^\//,''), true)||"",dir.themes[0], opts);
|
||||||
|
|
||||||
if(dir.style) styles = parse_sty(getzipdata(zip, dir.style.replace(/^\//,'')),dir.style, themes, opts);
|
if(dir.style) styles = parse_sty(getzipdata(zip, strip_front_slash(dir.style)), dir.style, themes, opts);
|
||||||
}
|
}
|
||||||
|
|
||||||
var wb = parse_wb(getzipdata(zip, dir.workbooks[0].replace(/^\//,'')), dir.workbooks[0], opts);
|
var externbooks = dir.links.map(function(link) {
|
||||||
|
return parse_xlink(getzipdata(zip, strip_front_slash(link)), link, opts);
|
||||||
|
});
|
||||||
|
|
||||||
|
var wb = parse_wb(getzipdata(zip, strip_front_slash(dir.workbooks[0])), dir.workbooks[0], opts);
|
||||||
|
|
||||||
var props = {}, propdata = "";
|
var props = {}, propdata = "";
|
||||||
|
|
||||||
if(dir.coreprops.length !== 0) {
|
if(dir.coreprops.length) {
|
||||||
propdata = getzipstr(zip, dir.coreprops[0].replace(/^\//,''), true);
|
propdata = getzipstr(zip, strip_front_slash(dir.coreprops[0]), true);
|
||||||
if(propdata) props = parse_core_props(propdata);
|
if(propdata) props = parse_core_props(propdata);
|
||||||
if(dir.extprops.length !== 0) {
|
if(dir.extprops.length !== 0) {
|
||||||
propdata = getzipstr(zip, dir.extprops[0].replace(/^\//,''), true);
|
propdata = getzipstr(zip, strip_front_slash(dir.extprops[0]), true);
|
||||||
if(propdata) parse_ext_props(propdata, props, opts);
|
if(propdata) parse_ext_props(propdata, props, opts);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -17270,7 +17377,7 @@ function parse_zip(zip, opts) {
|
|||||||
var custprops = {};
|
var custprops = {};
|
||||||
if(!opts.bookSheets || opts.bookProps) {
|
if(!opts.bookSheets || opts.bookProps) {
|
||||||
if (dir.custprops.length !== 0) {
|
if (dir.custprops.length !== 0) {
|
||||||
propdata = getzipstr(zip, dir.custprops[0].replace(/^\//,''), true);
|
propdata = getzipstr(zip, strip_front_slash(dir.custprops[0]), true);
|
||||||
if(propdata) custprops = parse_cust_props(propdata, opts);
|
if(propdata) custprops = parse_cust_props(propdata, opts);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -17286,7 +17393,7 @@ function parse_zip(zip, opts) {
|
|||||||
sheets = {};
|
sheets = {};
|
||||||
|
|
||||||
var deps = {};
|
var deps = {};
|
||||||
if(opts.bookDeps && dir.calcchain) deps=parse_cc(getzipdata(zip, dir.calcchain.replace(/^\//,'')),dir.calcchain,opts);
|
if(opts.bookDeps && dir.calcchain) deps=parse_cc(getzipdata(zip, strip_front_slash(dir.calcchain)),dir.calcchain,opts);
|
||||||
|
|
||||||
var i=0;
|
var i=0;
|
||||||
var sheetRels = ({});
|
var sheetRels = ({});
|
||||||
@ -17340,7 +17447,7 @@ function parse_zip(zip, opts) {
|
|||||||
out.files = zip.files;
|
out.files = zip.files;
|
||||||
}
|
}
|
||||||
if(opts.bookVBA) {
|
if(opts.bookVBA) {
|
||||||
if(dir.vba.length > 0) out.vbaraw = getzipdata(zip,dir.vba[0].replace(/^\//,''),true);
|
if(dir.vba.length > 0) out.vbaraw = getzipdata(zip,strip_front_slash(dir.vba[0]),true);
|
||||||
else if(dir.defaults && dir.defaults.bin === 'application/vnd.ms-office.vbaProject') out.vbaraw = getzipdata(zip,'xl/vbaProject.bin',true);
|
else if(dir.defaults && dir.defaults.bin === 'application/vnd.ms-office.vbaProject') out.vbaraw = getzipdata(zip,'xl/vbaProject.bin',true);
|
||||||
}
|
}
|
||||||
return out;
|
return out;
|
||||||
@ -17577,7 +17684,7 @@ function readSync(data, opts) {
|
|||||||
if(o.type == "file") { o.type = "buffer"; d = _fs.readFileSync(data); }
|
if(o.type == "file") { o.type = "buffer"; d = _fs.readFileSync(data); }
|
||||||
switch((n = firstbyte(d, o))[0]) {
|
switch((n = firstbyte(d, o))[0]) {
|
||||||
case 0xD0: return read_cfb(CFB.read(d, o), o);
|
case 0xD0: return read_cfb(CFB.read(d, o), o);
|
||||||
case 0x09: return parse_xlscfb(s2a(o.type === 'base64' ? Base64.decode(d) : d), o);
|
case 0x09: return parse_xlscfb(d, o);
|
||||||
case 0x3C: return parse_xlml(d, o);
|
case 0x3C: return parse_xlml(d, o);
|
||||||
case 0x49: if(n[1] == 0x44) return read_wb_ID(d, o); break;
|
case 0x49: if(n[1] == 0x44) return read_wb_ID(d, o); break;
|
||||||
case 0x54: if(n[1] == 0x41 && n[2] == 0x42 && n[3] == 0x4C) return DIF.to_workbook(d, o); break;
|
case 0x54: if(n[1] == 0x41 && n[2] == 0x42 && n[3] == 0x4C) return DIF.to_workbook(d, o); break;
|
||||||
|
@ -8,7 +8,7 @@ postMessage({t:"ready"});
|
|||||||
onmessage = function (oEvent) {
|
onmessage = function (oEvent) {
|
||||||
var v;
|
var v;
|
||||||
try {
|
try {
|
||||||
v = XLSX.read(oEvent.data.d, {type: oEvent.data.b ? 'binary' : 'base64'});
|
v = XLSX.read(oEvent.data.d, {type: oEvent.data.b});
|
||||||
|
postMessage({t:"xlsx", d:JSON.stringify(v)});
|
||||||
} catch(e) { postMessage({t:"e",d:e.stack||e}); }
|
} catch(e) { postMessage({t:"e",d:e.stack||e}); }
|
||||||
postMessage({t:"xlsx", d:JSON.stringify(v)});
|
|
||||||
};
|
};
|
||||||
|
@ -1,29 +0,0 @@
|
|||||||
/* xlsx.js (C) 2013-present SheetJS -- http://sheetjs.com */
|
|
||||||
/* uncomment the next line for encoding support */
|
|
||||||
importScripts('dist/cpexcel.js');
|
|
||||||
importScripts('jszip.js');
|
|
||||||
importScripts('xlsx.js');
|
|
||||||
postMessage({t:"ready"});
|
|
||||||
|
|
||||||
function ab2str(data) {
|
|
||||||
var o = "", l = 0, w = 10240;
|
|
||||||
for(; l<data.byteLength/w; ++l) o+=String.fromCharCode.apply(null,new Uint8Array(data.slice(l*w,l*w+w)));
|
|
||||||
o+=String.fromCharCode.apply(null, new Uint8Array(data.slice(l*w)));
|
|
||||||
return o;
|
|
||||||
}
|
|
||||||
|
|
||||||
function s2ab(s) {
|
|
||||||
var b = new ArrayBuffer(s.length*2), v = new Uint16Array(b);
|
|
||||||
for (var i=0; i != s.length; ++i) v[i] = s.charCodeAt(i);
|
|
||||||
return [v, b];
|
|
||||||
}
|
|
||||||
|
|
||||||
onmessage = function (oEvent) {
|
|
||||||
var v;
|
|
||||||
try {
|
|
||||||
v = XLSX.read(ab2str(oEvent.data), {type: 'binary'});
|
|
||||||
} catch(e) { postMessage({t:"e",d:e.stack}); }
|
|
||||||
var res = {t:"xlsx", d:JSON.stringify(v)};
|
|
||||||
var r = s2ab(res.d)[1];
|
|
||||||
postMessage(r, [r]);
|
|
||||||
};
|
|
@ -1,29 +0,0 @@
|
|||||||
/* xlsx.js (C) 2013-present SheetJS -- http://sheetjs.com */
|
|
||||||
/* uncomment the next line for encoding support */
|
|
||||||
importScripts('dist/cpexcel.js');
|
|
||||||
importScripts('jszip.js');
|
|
||||||
importScripts('xlsx.js');
|
|
||||||
postMessage({t:"ready"});
|
|
||||||
|
|
||||||
function ab2str(data) {
|
|
||||||
var o = "", l = 0, w = 10240;
|
|
||||||
for(; l<data.byteLength/w; ++l) o+=String.fromCharCode.apply(null,new Uint16Array(data.slice(l*w,l*w+w)));
|
|
||||||
o+=String.fromCharCode.apply(null, new Uint16Array(data.slice(l*w)));
|
|
||||||
return o;
|
|
||||||
}
|
|
||||||
|
|
||||||
function s2ab(s) {
|
|
||||||
var b = new ArrayBuffer(s.length*2), v = new Uint16Array(b);
|
|
||||||
for (var i=0; i != s.length; ++i) v[i] = s.charCodeAt(i);
|
|
||||||
return [v, b];
|
|
||||||
}
|
|
||||||
|
|
||||||
onmessage = function (oEvent) {
|
|
||||||
var v;
|
|
||||||
try {
|
|
||||||
v = XLSX.read(ab2str(oEvent.data), {type: 'binary'});
|
|
||||||
} catch(e) { postMessage({t:"e",d:e.stack}); }
|
|
||||||
var res = {t:"xlsx", d:JSON.stringify(v)};
|
|
||||||
var r = s2ab(res.d)[1];
|
|
||||||
postMessage(r, [r]);
|
|
||||||
};
|
|
Loading…
Reference in New Issue
Block a user