誰でも私に以下のJSON構文の問題点を教えてもらえますか? JsonLintによると、エラーは/ "csv"
という単語の前に始まります。私は構文のエラーを見ることはできませんが、そこにある必要があります。誰かが私の誤りの背後にある原則を私に教えていただけたらどうか。JSON構造体/構文
{
"lists": {
"csv": "function(head, req) {
var row,
first = true;
// output HTTP headers
start({
headers: {
'Content-Type': 'text/csv'
},
});
// iterate through the result set
while (row = getRow()) {
// get the doc (include_docs=true)
var doc = row.doc;
// if this is the first row
if (first) {
// output column headers
send(Object.keys(doc).join(',') + 'n');
first = false;
}
// build up a line of output
var line = '';
// iterate through each row
for (var i in doc) {
// comma separator
if (line.length > 0) {
line += ',';
}
// output the value, ensuring values that themselves
// contain commas are enclosed in double quotes
var val = doc[i];
if (typeof val == 'string' && val.indexOf(',') > -1) {
line += '" ' + val.replace(/"/g, ' "" ') + ' "';
} else {
line += val;
}
}
line += 'n';
// send the line
send(line);
}
}
"
}
}
EDIT:
全コード(CouchDBのビュー/リスト):
{
"_id": "_design/comptno",
"_rev": "2-4531ba9fd5bcd6b7fbc5bc8555f0bfe3",
"views": {
"list_example": {
"map": "function(doc) {\r\n if (doc.compartment.number) {\r\n emit(doc.compartment.number, null);\r\n }\r\n};"
},
"list_example2": {
"map": "function(doc) {\r\n if (doc.compartment.number) {\r\n emit(doc.compartment.number, null);\r\n }\r\n};"
}
},
"lists":{"csv":"function(head, req) { var row, first = true; // output HTTP headers start({ headers: { 'Content-Type': 'text/csv' }, }); // iterate through the result set while (row = getRow()) { // get the doc (include_docs=true) var doc = row.doc; // if this is the first row if (first) { // output column headers send(Object.keys(doc).join(',') + 'n'); first = false; } // build up a line of output var line = ''; // iterate through each row for (var i in doc) { // comma separator if (line.length > 0) { line += ','; } // output the value, ensuring values that themselves // contain commas are enclosed in double quotes var val = doc[i]; if (typeof val == 'string' && val.indexOf(',') > -1) { line += '"' + val.replace(/"/g, '""') + '"'; } else { line += val; } } line += 'n'; // send the line send(line); }}"},
"language": "javascript"
}
あなたは文字列値に改行を持つことができません。 – JJJ
[JsonLintの無効なJsonエラー]の可能な複製(http://stackoverflow.com/questions/21675038/invalid-json-error-in-jsonlint) – JJJ
@JJJコメントありがとうございます。全体的な文書を含め、縮小されたjsonの編集を追加しました。私はダブルチェックとしてhttp://codebeautify.org/jsonvalidatorを使用しました。 JsonLintとCodeBeautifyは両方ともこの地域を誤って指摘しています: 'line + =' "'+ val.replace(/"、 "" "')+ ''コードはCloudantウェブサイトに掲載されています。 。 [link](https://developer.ibm.com/clouddataservices/2015/09/22/export-cloudant-json-as-csv-rss-orical/) – jlb333333