D3 stacked area chart tsv to csv conversion problems

前端 未结 1 1373
有刺的猬
有刺的猬 2021-01-26 05:15

I am trying to convert this example from tsv to csv.

Currently this is what I have: https://jsfiddle.net/asb1926/sc5wdkLe/

The error I keep getting is this (on

相关标签:
1条回答
  • 2021-01-26 05:56

    Your date strings have a different format. This is Bostock's dates:

    "2015 Jun 15"
    

    This is yours:

    "04/23/12"
    

    Therefore, you need a different parser:

    var parseDate = d3.timeParse("%m/%d/%Y");
    

    Besides that, your path d attribute is wrong. It should be simply:

    .attr("d", area);
    

    Here is your code with that changes:

    var svg = d3.select("svg"),
      margin = {
        top: 20,
        right: 20,
        bottom: 30,
        left: 50
      },
      width = svg.attr("width") - margin.left - margin.right,
      height = svg.attr("height") - margin.top - margin.bottom;
    
    var parseDate = d3.timeParse("%m/%d/%Y");
    
    var x = d3.scaleTime().range([0, width]),
      y = d3.scaleLinear().range([height, 0]),
      z = d3.scaleOrdinal(d3.schemeCategory10);
    
    var stack = d3.stack();
    
    var area = d3.area()
      .x(function(d, i) {
        return x(d.data.date);
      })
      .y0(function(d) {
        return y(d[0]);
      })
      .y1(function(d) {
        return y(d[1]);
      });
    
    var g = svg.append("g")
      .attr("transform", "translate(" + margin.left + "," + margin.top + ")");
    
    var data = d3.csvParse(d3.select("#csv").text(), type)
    
    var keys = data.columns.slice(1);
    
    x.domain(d3.extent(data, function(d) {
      return d.date;
    }));
    z.domain(keys);
    stack.keys(keys);
    
    var layer = g.selectAll(".layer")
      .data(stack(data))
      .enter().append("g")
      .attr("class", "layer");
    
    layer.append("path")
      .attr("class", "area")
      .style("fill", function(d) {
        return z(d.key);
      })
      .attr("d", area);
    
    layer.filter(function(d) {
        return d[d.length - 1][1] - d[d.length - 1][0] > 0.01;
      })
      .append("text")
      .attr("x", width - 6)
      .attr("y", function(d) {
        return y((d[d.length - 1][0] + d[d.length - 1][1]) / 2);
      })
      .attr("dy", ".35em")
      .style("font", "10px sans-serif")
      .style("text-anchor", "end")
      .text(function(d) {
        return d.key;
      });
    
    g.append("g")
      .attr("class", "axis axis--x")
      .attr("transform", "translate(0," + height + ")")
      .call(d3.axisBottom(x));
    
    g.append("g")
      .attr("class", "axis axis--y")
      .call(d3.axisLeft(y).ticks(10, "%"));
    
    
    function type(d, i, columns) {
      d.date = parseDate(d.date);
      for (var i = 1, n = columns.length; i < n; ++i) d[columns[i]] = d[columns[i]] / 100;
      return d;
    }
    pre {
      display: none;
    }
    <script src="https://d3js.org/d3.v4.min.js"></script>
    <svg width="500" height="300"></svg>
    <pre id="csv">date,Detractors,Promoters,Passives
    04/23/12,37,12,46
    04/24/12,32,19,42
    04/25/12,45,16,44
    04/26/12,24,52,64</pre>

    PS: I'm using a <pre> element to store the CSV, because I cannot use a real CSV in the Stack snippet.

    0 讨论(0)
提交回复
热议问题