Browse Source

Implement quotes config optionally as function (#703)

pull/704/head
Puzzles 5 years ago committed by Sergi Almacellas Abellana
parent
commit
80a1044f1b
  1. 2
      docs/docs.html
  2. 14
      papaparse.js
  3. 12
      tests/test-cases.js

2
docs/docs.html

@ -282,7 +282,7 @@
<code>quotes</code> <code>quotes</code>
</td> </td>
<td> <td>
If <code>true</code>, forces all fields to be enclosed in quotes. If an array of <code>true/false</code> values, specifies which fields should be force-quoted (first boolean is for the first column, second boolean for the second column, ...). If <code>true</code>, forces all fields to be enclosed in quotes. If an array of <code>true/false</code> values, specifies which fields should be force-quoted (first boolean is for the first column, second boolean for the second column, ...). A function that returns a boolean values can be used to determine the quotes value of a cell. This function accepts the cell value and column index as parameters.
</td> </td>
</tr> </tr>
<tr> <tr>

14
papaparse.js

@ -334,6 +334,7 @@ License: MIT
} }
if (typeof _config.quotes === 'boolean' if (typeof _config.quotes === 'boolean'
|| typeof _config.quotes === 'function'
|| Array.isArray(_config.quotes)) || Array.isArray(_config.quotes))
_quotes = _config.quotes; _quotes = _config.quotes;
@ -446,16 +447,17 @@ License: MIT
if (str.constructor === Date) if (str.constructor === Date)
return JSON.stringify(str).slice(1, 25); return JSON.stringify(str).slice(1, 25);
str = str.toString().replace(quoteCharRegex, _escapedQuote); var escapedQuoteStr = str.toString().replace(quoteCharRegex, _escapedQuote);
var needsQuotes = (typeof _quotes === 'boolean' && _quotes) var needsQuotes = (typeof _quotes === 'boolean' && _quotes)
|| (typeof _quotes === 'function' && _quotes(str, col))
|| (Array.isArray(_quotes) && _quotes[col]) || (Array.isArray(_quotes) && _quotes[col])
|| hasAny(str, Papa.BAD_DELIMITERS) || hasAny(escapedQuoteStr, Papa.BAD_DELIMITERS)
|| str.indexOf(_delimiter) > -1 || escapedQuoteStr.indexOf(_delimiter) > -1
|| str.charAt(0) === ' ' || escapedQuoteStr.charAt(0) === ' '
|| str.charAt(str.length - 1) === ' '; || escapedQuoteStr.charAt(escapedQuoteStr.length - 1) === ' ';
return needsQuotes ? _quoteChar + str + _quoteChar : str; return needsQuotes ? _quoteChar + escapedQuoteStr + _quoteChar : escapedQuoteStr;
} }
function hasAny(str, substrings) function hasAny(str, substrings)

12
tests/test-cases.js

@ -1711,6 +1711,18 @@ var UNPARSE_TESTS = [
config: { quotes: [true, false, true] }, config: { quotes: [true, false, true] },
expected: '"Col1",Col2,"Col3"\r\n"a",b,"c"\r\n"d",e,"f"' expected: '"Col1",Col2,"Col3"\r\n"a",b,"c"\r\n"d",e,"f"'
}, },
{
description: "Force quotes around string fields only",
input: [['a', 'b', 'c'], ['d', 10, true]],
config: { quotes: function(value) { return typeof value === 'string'; } },
expected: '"a","b","c"\r\n"d",10,true'
},
{
description: "Force quotes around string fields only (with header row)",
input: [{ "Col1": "a", "Col2": "b", "Col3": "c" }, { "Col1": "d", "Col2": 10, "Col3": true }],
config: { quotes: function(value) { return typeof value === 'string'; } },
expected: '"Col1","Col2","Col3"\r\n"a","b","c"\r\n"d",10,true'
},
{ {
description: "Empty input", description: "Empty input",
input: [], input: [],

Loading…
Cancel
Save