crossfilter.js非常适合于识别与特定数据维连续段相匹配的数据点。这通常是您想要的行为,但我有一个特殊的用例,可以方便地知道不匹配任何选定筛选器的数据点集。是否有一种方法可以在crossfilter.js中获得所选维度的补充?
作为一个具体的例子,当您加载crossfilter.js页面时,我想知道不在二月的所有航班的列表(预先指定的日期范围)。
发布于 2014-01-07 14:25:17
在编写本报告时,没有一种简单的方法来补充给定的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.
}发布于 2014-01-04 14:20:15
我认为使用函数的筛选日期维有助于补充(空气污染指数参考)
//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 Februaryhttps://stackoverflow.com/questions/20919591
复制相似问题