200 lines
No EOL
22 KiB
JavaScript
200 lines
No EOL
22 KiB
JavaScript
"use strict";
|
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
};
|
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
var CSVError_1 = __importDefault(require("./CSVError"));
|
|
var set_1 = __importDefault(require("lodash/set"));
|
|
var numReg = /^[-+]?[0-9]*\.?[0-9]+([eE][-+]?[0-9]+)?$/;
|
|
function default_1(csvRows, conv) {
|
|
var res = [];
|
|
for (var i = 0, len = csvRows.length; i < len; i++) {
|
|
var r = processRow(csvRows[i], conv, i);
|
|
if (r) {
|
|
res.push(r);
|
|
}
|
|
}
|
|
return res;
|
|
}
|
|
exports.default = default_1;
|
|
;
|
|
function processRow(row, conv, index) {
|
|
if (conv.parseParam.checkColumn && conv.parseRuntime.headers && row.length !== conv.parseRuntime.headers.length) {
|
|
throw (CSVError_1.default.column_mismatched(conv.parseRuntime.parsedLineNumber + index));
|
|
}
|
|
var headRow = conv.parseRuntime.headers || [];
|
|
var resultRow = convertRowToJson(row, headRow, conv);
|
|
if (resultRow) {
|
|
return resultRow;
|
|
}
|
|
else {
|
|
return null;
|
|
}
|
|
}
|
|
function convertRowToJson(row, headRow, conv) {
|
|
var hasValue = false;
|
|
var resultRow = {};
|
|
for (var i = 0, len = row.length; i < len; i++) {
|
|
var item = row[i];
|
|
if (conv.parseParam.ignoreEmpty && item === '') {
|
|
continue;
|
|
}
|
|
hasValue = true;
|
|
var head = headRow[i];
|
|
if (!head || head === "") {
|
|
head = headRow[i] = "field" + (i + 1);
|
|
}
|
|
var convFunc = getConvFunc(head, i, conv);
|
|
if (convFunc) {
|
|
var convRes = convFunc(item, head, resultRow, row, i);
|
|
if (convRes !== undefined) {
|
|
setPath(resultRow, head, convRes, conv, i);
|
|
}
|
|
}
|
|
else {
|
|
// var flag = getFlag(head, i, param);
|
|
// if (flag === 'omit') {
|
|
// continue;
|
|
// }
|
|
if (conv.parseParam.checkType) {
|
|
var convertFunc = checkType(item, head, i, conv);
|
|
item = convertFunc(item);
|
|
}
|
|
if (item !== undefined) {
|
|
setPath(resultRow, head, item, conv, i);
|
|
}
|
|
}
|
|
}
|
|
if (hasValue) {
|
|
return resultRow;
|
|
}
|
|
else {
|
|
return null;
|
|
}
|
|
}
|
|
var builtInConv = {
|
|
"string": stringType,
|
|
"number": numberType,
|
|
"omit": function () { }
|
|
};
|
|
function getConvFunc(head, i, conv) {
|
|
if (conv.parseRuntime.columnConv[i] !== undefined) {
|
|
return conv.parseRuntime.columnConv[i];
|
|
}
|
|
else {
|
|
var flag = conv.parseParam.colParser[head];
|
|
if (flag === undefined) {
|
|
return conv.parseRuntime.columnConv[i] = null;
|
|
}
|
|
if (typeof flag === "object") {
|
|
flag = flag.cellParser || "string";
|
|
}
|
|
if (typeof flag === "string") {
|
|
flag = flag.trim().toLowerCase();
|
|
var builtInFunc = builtInConv[flag];
|
|
if (builtInFunc) {
|
|
return conv.parseRuntime.columnConv[i] = builtInFunc;
|
|
}
|
|
else {
|
|
return conv.parseRuntime.columnConv[i] = null;
|
|
}
|
|
}
|
|
else if (typeof flag === "function") {
|
|
return conv.parseRuntime.columnConv[i] = flag;
|
|
}
|
|
else {
|
|
return conv.parseRuntime.columnConv[i] = null;
|
|
}
|
|
}
|
|
}
|
|
function setPath(resultJson, head, value, conv, headIdx) {
|
|
if (!conv.parseRuntime.columnValueSetter[headIdx]) {
|
|
if (conv.parseParam.flatKeys) {
|
|
conv.parseRuntime.columnValueSetter[headIdx] = flatSetter;
|
|
}
|
|
else {
|
|
if (head.indexOf(".") > -1) {
|
|
if (conv.parseParam.colParser[head] && conv.parseParam.colParser[head].flat) {
|
|
conv.parseRuntime.columnValueSetter[headIdx] = flatSetter;
|
|
}
|
|
else {
|
|
conv.parseRuntime.columnValueSetter[headIdx] = jsonSetter;
|
|
}
|
|
}
|
|
else {
|
|
conv.parseRuntime.columnValueSetter[headIdx] = flatSetter;
|
|
}
|
|
}
|
|
}
|
|
conv.parseRuntime.columnValueSetter[headIdx](resultJson, head, value);
|
|
// flatSetter(resultJson, head, value);
|
|
}
|
|
function flatSetter(resultJson, head, value) {
|
|
resultJson[head] = value;
|
|
}
|
|
function jsonSetter(resultJson, head, value) {
|
|
set_1.default(resultJson, head, value);
|
|
}
|
|
function checkType(item, head, headIdx, conv) {
|
|
if (conv.parseRuntime.headerType[headIdx]) {
|
|
return conv.parseRuntime.headerType[headIdx];
|
|
}
|
|
else if (head.indexOf('number#!') > -1) {
|
|
return conv.parseRuntime.headerType[headIdx] = numberType;
|
|
}
|
|
else if (head.indexOf('string#!') > -1) {
|
|
return conv.parseRuntime.headerType[headIdx] = stringType;
|
|
}
|
|
else if (conv.parseParam.checkType) {
|
|
return conv.parseRuntime.headerType[headIdx] = dynamicType;
|
|
}
|
|
else {
|
|
return conv.parseRuntime.headerType[headIdx] = stringType;
|
|
}
|
|
}
|
|
function numberType(item) {
|
|
var rtn = parseFloat(item);
|
|
if (isNaN(rtn)) {
|
|
return item;
|
|
}
|
|
return rtn;
|
|
}
|
|
function stringType(item) {
|
|
return item.toString();
|
|
}
|
|
function dynamicType(item) {
|
|
var trimed = item.trim();
|
|
if (trimed === "") {
|
|
return stringType(item);
|
|
}
|
|
if (numReg.test(trimed)) {
|
|
return numberType(item);
|
|
}
|
|
else if (trimed.length === 5 && trimed.toLowerCase() === "false" || trimed.length === 4 && trimed.toLowerCase() === "true") {
|
|
return booleanType(item);
|
|
}
|
|
else if (trimed[0] === "{" && trimed[trimed.length - 1] === "}" || trimed[0] === "[" && trimed[trimed.length - 1] === "]") {
|
|
return jsonType(item);
|
|
}
|
|
else {
|
|
return stringType(item);
|
|
}
|
|
}
|
|
function booleanType(item) {
|
|
var trimed = item.trim();
|
|
if (trimed.length === 5 && trimed.toLowerCase() === "false") {
|
|
return false;
|
|
}
|
|
else {
|
|
return true;
|
|
}
|
|
}
|
|
function jsonType(item) {
|
|
try {
|
|
return JSON.parse(item);
|
|
}
|
|
catch (e) {
|
|
return item;
|
|
}
|
|
}
|
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"/Users/kxiang/work/projects/csv2json/src/lineToJson.ts","sources":["/Users/kxiang/work/projects/csv2json/src/lineToJson.ts"],"names":[],"mappings":"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","sourcesContent":["import { Converter } from \"./Converter\";\nimport CSVError from \"./CSVError\";\nimport { CellParser, ColumnParam } from \"./Parameters\";\nimport set from \"lodash/set\";\nimport { ParseRuntime } from \"./ParseRuntime\";\n\nvar numReg = /^[-+]?[0-9]*\\.?[0-9]+([eE][-+]?[0-9]+)?$/;\n\nexport default function (csvRows: string[][], conv: Converter): JSONResult[] {\n  const res: JSONResult[] = [];\n  for (let i = 0, len = csvRows.length; i < len; i++) {\n    const r = processRow(csvRows[i], conv, i);\n    if (r) {\n      res.push(r);\n    }\n  }\n  return res;\n};\nexport type JSONResult = {\n  [key: string]: any\n}\n\nfunction processRow(row: string[], conv: Converter, index): JSONResult | null {\n\n  if (conv.parseParam.checkColumn && conv.parseRuntime.headers && row.length !== conv.parseRuntime.headers.length) {\n    throw (CSVError.column_mismatched(conv.parseRuntime.parsedLineNumber + index))\n  }\n\n  const headRow = conv.parseRuntime.headers || [];\n  const resultRow = convertRowToJson(row, headRow, conv);\n  if (resultRow) {\n    return resultRow;\n  } else {\n    return null;\n  }\n}\n\nfunction convertRowToJson(row: string[], headRow: string[], conv: Converter): { [key: string]: any } | null {\n  let hasValue = false;\n  const resultRow = {};\n  \n  for (let i = 0, len = row.length; i < len; i++) {\n    let item = row[i];\n\n    if (conv.parseParam.ignoreEmpty && item === '') {\n      continue;\n    }\n    hasValue = true;\n\n    let head = headRow[i];\n    if (!head || head === \"\") {\n      head = headRow[i] = \"field\" + (i + 1);\n    }\n    const convFunc = getConvFunc(head, i, conv);\n    if (convFunc) {\n      const convRes = convFunc(item, head, resultRow, row, i);\n      if (convRes !== undefined) {\n        setPath(resultRow, head, convRes, conv,i);\n      }\n    } else {\n      // var flag = getFlag(head, i, param);\n      // if (flag === 'omit') {\n      //   continue;\n      // }\n      if (conv.parseParam.checkType) {\n        const convertFunc = checkType(item, head, i, conv);\n        item = convertFunc(item);\n      }\n      if (item !== undefined) {\n        setPath(resultRow, head, item, conv,i);\n      }\n    }\n  }\n  if (hasValue) {\n    return resultRow;\n  } else {\n    return null;\n  }\n}\n\nconst builtInConv: { [key: string]: CellParser } = {\n  \"string\": stringType,\n  \"number\": numberType,\n  \"omit\": function () { }\n}\nfunction getConvFunc(head: string, i: number, conv: Converter): CellParser | null {\n  if (conv.parseRuntime.columnConv[i] !== undefined) {\n    return conv.parseRuntime.columnConv[i];\n  } else {\n    let flag = conv.parseParam.colParser[head];\n    if (flag === undefined) {\n      return conv.parseRuntime.columnConv[i] = null;\n    }\n    if (typeof flag === \"object\") {\n      flag = (flag as ColumnParam).cellParser || \"string\";\n    }\n    if (typeof flag === \"string\") {\n      flag = flag.trim().toLowerCase();\n      const builtInFunc = builtInConv[flag];\n      if (builtInFunc) {\n        return conv.parseRuntime.columnConv[i] = builtInFunc;\n      } else {\n        return conv.parseRuntime.columnConv[i] = null;\n      }\n    } else if (typeof flag === \"function\") {\n      return conv.parseRuntime.columnConv[i] = flag;\n    } else {\n      return conv.parseRuntime.columnConv[i] = null;\n    }\n  }\n}\nfunction setPath(resultJson: any, head: string, value: any, conv: Converter,headIdx:number) {\n  if (!conv.parseRuntime.columnValueSetter[headIdx]) {\n    if (conv.parseParam.flatKeys) {\n      conv.parseRuntime.columnValueSetter[headIdx] = flatSetter;\n    } else {\n      if (head.indexOf(\".\") > -1) {\n        if (conv.parseParam.colParser[head] && (conv.parseParam.colParser[head] as ColumnParam).flat) {\n          conv.parseRuntime.columnValueSetter[headIdx] = flatSetter;\n        } else {\n          conv.parseRuntime.columnValueSetter[headIdx] = jsonSetter;\n        }\n      } else {\n        conv.parseRuntime.columnValueSetter[headIdx] = flatSetter;\n      }\n    }\n  }\n  conv.parseRuntime.columnValueSetter[headIdx](resultJson, head, value);\n  // flatSetter(resultJson, head, value);\n\n}\nfunction flatSetter(resultJson: any, head: string, value: any) {\n  resultJson[head] = value;\n}\nfunction jsonSetter(resultJson: any, head: string, value: any) {\n  set(resultJson, head, value);\n}\n\n\nfunction checkType(item: string, head: string, headIdx: number, conv: Converter): Function {\n  if (conv.parseRuntime.headerType[headIdx]) {\n    return conv.parseRuntime.headerType[headIdx];\n  } else if (head.indexOf('number#!') > -1) {\n    return conv.parseRuntime.headerType[headIdx] = numberType;\n  } else if (head.indexOf('string#!') > -1) {\n    return conv.parseRuntime.headerType[headIdx] = stringType;\n  } else if (conv.parseParam.checkType) {\n    return conv.parseRuntime.headerType[headIdx] = dynamicType;\n  } else {\n    return conv.parseRuntime.headerType[headIdx] = stringType;\n  }\n}\n\nfunction numberType(item) {\n  var rtn = parseFloat(item);\n  if (isNaN(rtn)) {\n    return item;\n  }\n  return rtn;\n}\n\nfunction stringType(item: string): string {\n  return item.toString();\n}\n\nfunction dynamicType(item) {\n  var trimed = item.trim();\n  if (trimed === \"\") {\n    return stringType(item);\n  }\n  if (numReg.test(trimed)) {\n    return numberType(item);\n  } else if (trimed.length === 5 && trimed.toLowerCase() === \"false\" || trimed.length === 4 && trimed.toLowerCase() === \"true\") {\n    return booleanType(item);\n  } else if (trimed[0] === \"{\" && trimed[trimed.length - 1] === \"}\" || trimed[0] === \"[\" && trimed[trimed.length - 1] === \"]\") {\n    return jsonType(item);\n  } else {\n    return stringType(item);\n  }\n}\n\nfunction booleanType(item) {\n  var trimed = item.trim();\n  if (trimed.length === 5 && trimed.toLowerCase() === \"false\") {\n    return false;\n  } else {\n    return true;\n  }\n}\n\nfunction jsonType(item) {\n  try {\n    return JSON.parse(item);\n  } catch (e) {\n    return item;\n  }\n}\n"]}
|