crossfilter.js中的补集集?

时间:2014-01-04 10:13:34

标签: javascript crossfilter

crossfilter.js非常适合识别与特定连续数据维度段匹配的数据点。这通常是您想要的确切行为,但我有一个特殊的用例,可以方便地知道不匹配任何选定过滤器的数据点集。有没有办法在crossfilter.js中获得所选维度的补充?

作为一个具体示例,当您加载crossfilter.js page时,我想知道所有不在二月(预先指定的日期范围)的航班列表。

2 个答案:

答案 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