crossfilter.js非常适合识别与特定连续数据维度段匹配的数据点。这通常是您想要的确切行为,但我有一个特殊的用例,可以方便地知道不匹配任何选定过滤器的数据点集。有没有办法在crossfilter.js中获得所选维度的补充?
作为一个具体示例,当您加载crossfilter.js page时,我想知道所有不在二月(预先指定的日期范围)的航班列表。
答案 0 :(得分:4)
在撰写本文时,没有直接的方法来补充给定Crossfilter实例的当前过滤器集。这样的操作会重新计算所有组,以便它们匹配补充的过滤器。
如果您只是想要一个与当前过滤器集不匹配的记录列表,那么它并不是很简单,但您可以考虑迭代所有记录的数组(按特定顺序),并与匹配数组进行比较记录(按相同顺序)。
例如:
var db = crossfilter(data),
date = db.dimension(function(d) { return d.date; }),
recordsByDate = date.top(Infinity),
n = db.size();
// Add some filters here on various dimensions…
date.filterRange([0, 31536e6]);
// Retrieve matching records in date order.
var matchesByDate = date.top(Infinity),
m = matchesByDate.length;
// Iterate over all records in date order, and compare with matching records.
for (var i = 0, j = 0; i < n && j < m; ++i) {
if (recordsByDate[i] === matchesByDate[j]) {
// Ignore matches.
++j;
continue;
}
// Otherwise, non-matching record: process immediately or add to an array.
}
答案 1 :(得分:0)
我认为过滤日期维度与功能有助于补充 (api reference)
//from code in crossfilter.js page http://square.github.io/crossfilter/
//var flight = crossfilter(flights),
// date = flight.dimension(function(d) { return d.date;});
date.filter(function(d) { return d.getMonth() != 1; }); // flight data not in February