【问题标题】:XAxis time scale from csv data来自 csv 数据的 XAxis 时间刻度
【发布时间】:2015-11-30 17:03:56
【问题描述】:

虽然我已经阅读了关于这个主题的几篇文章,但我可以申请我的案例。我的数据源是来自 url 的 csv 格式。当我使用 d3.js 表示它们时,X 轴显示精确的分钟。怎么能代表每 30 分钟的时间分数? 时间格式csv url数据:

created_at,entry_id,field1,field2
2015-11-24 10:39:37 UTC,1049233,4,10
2015-11-24 11:09:37 UTC,1049234,0,10
2015-11-24 11:39:36 UTC,1049235,2,12

,所以: X轴:---10:39-----------11:09-----------11:39-----------

我的对象:

X轴:---10:30-----------11:00-----------11:30---------- -

这是我正在使用的代码:

var margin = { top: 20, right: -30, bottom: 120, left: 40 },
        width = 700 - margin.left - margin.right,
        height = 350 - margin.top - margin.bottom;

    // Parse the date / time
    var parseDate = d3.time.format("%Y-%m-%d %H:%M:%S UTC").parse;

    var x = d3.scale.ordinal().rangeRoundBands([0, width], .6);

    var y = d3.scale.linear().range([height, 0]);



    var xAxis = d3.svg.axis()
        .scale(x)
        .orient("bottom")
        .tickFormat(d3.time.format,30)
        .tickFormat(function(d) { return d3.time.format('%H:%M')(new Date(d)) })

    var yAxis = d3.svg.axis()
        .scale(y)
        .orient("left")
        .ticks(10);

    var svg = d3.select("body").append("svg")
        .attr("width", width + margin.left + margin.right)
        .attr("height", height + margin.top + margin.bottom)
      .append("g")
        .attr("transform",
              "translate(" + margin.left + "," + margin.top + ")");

,以及 csv 数据:

d3.csv("https://website/dat.csv",
        function (error, data) {
        data.forEach(function (d) {
            d.date = (d.created_at);
            d.value = +d.field1;
            console.log(d.value);
        });

        x.domain(data.map(function (d) { return d.date; }));
        y.domain([0, d3.max(data, function (d) { return d.value; })]);

        svg.append("g")
            .attr("class", "x axis")
            .attr("transform", "translate(7," + height + ")")
            .call(xAxis)
          .selectAll("text")
            .style("text-anchor", "end")
            .attr("dx", "-.9em")
            .attr("dy", "-.55em")
            .attr("transform", "rotate(-90)");

        svg.append("g")
            .attr("class", "y axis")
            .call(yAxis)
          .append("text")
            .attr("transform", "rotate(-90)")
            .attr("y", 6)
            .attr("dy", ".71em")
            .style("text-anchor", "end")
            .text("Nº Personas");

        svg.selectAll("bar")
            .data(data)
            .enter().append("rect")
            .style("fill", "steelblue")
            .attr("x", function (d) { return x(d.date); })
            .attr("width", x.rangeBand())
            .attr("y", function (d) { return y(d.value); })
            .attr("height", function (d) { return height - y(d.value); });
    });

提前致谢。

【问题讨论】:

  • 最终的对象是比较两个不同时间序列的csv url数据。

标签: javascript csv d3.js


【解决方案1】:

如果您确定数据是 hh:3m 格式,则可以使用

var xAxis = d3.svg.axis()
        .scale(x)
        .orient("bottom")
        .tickFormat(d3.time.format,30)
        .tickFormat(
            function(d) { 
                var toDisplay = d3.time.format('%H:%M')(new Date(d));
                    toDisplay = toDisplay.substring(0,3) + "0";
                    return toDisplay;
                    })

(你明白了,即使数据是其他格式,你也可以在函数内部更改它并以所需的格式返回)

【讨论】:

  • 谢谢。效果很好!!但是我正在使用另一个 csv url 源数据与主对象来比较两个 csv url 数据。第二个 url csv 数据的偏移量为 x(在这种情况下为 6)分钟,因此:(第二个 csv url 数据)created_at, entry_id,field1,field2 2015-11-24 10:39:37 UTC,1049713,4,10 2015-11-24 11:09:37 UTC,1049714,0,10 2015-11-24 11:39:36 UTC ,1049715,2,12 ,并且 X 标签从第一个 csv 偏移。
  • 没听懂,您能否编辑问题并包含这些详细信息或尝试在 cmets 中更好地解释它:)
  • 好的,我会在 cmets 中解释得更好。我已经使用了您的解决方案,并且修改我的代码效果更好。非常感谢。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2019-07-14
  • 2013-08-17
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多