问题描述
我正在从结构数组转换为查询,效果很好,但是在我拥有数组和嵌套结构的情况下,我有点迷失了我应该在函数中修改的内容,以获取具有更改后的数据的查询。
<cfscript>
data = [
{"1" :
{ i: 1,label: "One" }
},{"2" :{ i: 2,label: "Two",foo: "Foo" }},{"3" :{ i: 3,label: "Three",bar: "Bar" }},{"4" :{ i: 4,label: "Four",foo: "Foo",bar: "Bar" }}
];
function stackoverflow(data) {
return data.reduce(function(accumulator,element) {
element.each(function(key) {
if (!accumulator.keyExists(key)) {
accumulator.addColumn(key,[]);
}
});
accumulator.addRow(element);
return accumulator;
},QueryNew(""));
}
writeDump(data); abort;
writeDump(arrayToQuery(data));
</cfscript>
上面的方法是有效的,如果它是一个简单的ArrayofStructs,但是一旦我添加了一个结构级别,它就会停止工作
解决方法
为什么不首先将嵌套数组格式化为更简单的数组格式,然后再进行归约,就像这样。总会有更好的解决方案,但是所有解决方案都取决于您应用程序中的业务逻辑。
<cfscript>
data = [
{"1" :{ i: 1,label: "One" }},{"2" :{ i: 2,label: "Two",foo: "Foo" }},{"3" :{ i: 3,label: "Three",bar: "Bar" }},{"4" :{ i: 4,label: "Four",foo: "Foo",bar: "Bar" }}
];
function arrayToQuery(data) {
return data.map(function(datum,index){
return datum[index];
}).reduce(
function(accumulator,element) {
element.each(function(key) {
if (!accumulator.keyExists(key)) {
accumulator.addColumn(key,[]);
}
});
accumulator.addRow(element);
return accumulator;
},QueryNew("")
);
}
writeDump(data);
writeDump(arrayToQuery(data));
</cfscript>