2014-02-25 69 views
0

我JSON的類似如下:使用多個值的Crossfilter尺寸

[ 
    { 
     "source": "Google", 
     "date": "2014-02-01", 
     "spend": 21, 
     "clicks": 1000 
    }, 
    { 
     "source": "Bing", 
     "date": "2014-02-01", 
     "spend": 5, 
     "clicks": 541 
    }, 
    { 
     "source": "Google", 
     "date": "2014-02-02", 
     "spend": 24, 
     "clicks": 1029 
    }, 
    { 
     "source": "Bing", 
     "date": "2014-02-02", 
     "spend": 12, 
     "clicks": 754 
    } 
] 

並希望將其送入Crossfilter創建具有NVD3線圖。我不知道從哪裏開始,但我想折線圖使用如下:

  • X軸 - 日期
  • Y軸 - 點擊次數每源
  • 1線

這是我在沒有Crossfilter的情況下能夠建立的:

(function() { 
    var ymdFormat = d3.time.format('%Y-%m-%d'); 
    d3.json('./data.json', function (err, json) { 
     nv.addGraph(function() { 
      var chart = nv.models.lineChart() 
      chart.margin({ left: 100 }) 
        .useInteractiveGuideline(true) 
        .transitionDuration(350) 
        .showLegend(true) 
        .showYAxis(true).showXAxis(true); 
      chart.xAxis 
        .axisLabel('Date') 
        .tickFormat(function (d) { 
          return d3.time.format('%b %Y')(new Date(d)); 
        }); 
      chart.yAxis 
        .axisLabel('Clicks') 
        .tickFormat(d3.format(',')); 

      data = parseData(json); 

      d3.select('#graph').append('svg') 
       .datum(data).call(chart); 
     }); 
    }) 

    function parseData(json) { 
     var data, result, key; 
     data = {}; 
     json.forEach(function (elmt) { 
      if (!(elmt.source in data)) { 
       data[elmt.source] = { values: [] } 
      } 
      data[elmt.source].values.push({ x: ymdFormat.parse(elmt.date), y: elmt.clicks }) 
     }); 

     result = []; 
     for (key in data) { 
      if (data.hasOwnProperty(key)) { 
       result.push({ 
        key: key, 
        values: data[key].values 
       }); 
      } 
     } 
     console.log(result); 
     return result; 
    } 
})() 
+0

嗨戴夫,你有沒有找到答案呢?我加了我的解決方案。 –

回答

0

我有這個問題。但我有一個解決方案,但不是很好。

var filterByMonthSource = filter.dimension(function(d) { return d.date + ':' + d.source }); 
var clicksGroup = filterByMonth.group().reduceSum(function(d) { return d.clicks }); 
var clicksData = clicksGroup.all(); 

clicksData將有[{鍵: 「2014年2月1日:谷歌」,值:...},...]

然後我必須打破clicksData到3場的陣列。