如何解决将嵌套结构的数组转换为查询
我正在从结构数组转换为查询,效果很好,但是在我拥有数组和嵌套结构的情况下,我有点迷失了我应该在函数中修改的内容,以获取具有更改后的数据的查询。
<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>
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。