17

D3 で単純な散布図プログラムを適応させて、CSV ファイルを受け入れようとしています。ファイル内のデータを使用すると問題なく動作しますが、CSV ファイルを読み込もうとすると動作しません。私が見逃している簡単なものはありますか?CSVファイル「datatest.csv」の内容は、コード内のデータセットと同じです。ブラウザがデータを読み込んでいることを確認しましたが、すべてそこにあるようです。私は単にステップを逃していると思います。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>D3 Demo: Linear scales</title>
    <script type="text/javascript" src="../d3/d3.v3.js"></script>
    <style type="text/css">
        /* No style rules here yet */       
    </style>
</head>
<body>
    <script type="text/javascript">

        //Width and height
        var w = 900;
        var h = 500;
        var padding = 20;
        var dataset = [];

//          var dataset = [
//                          [5, 20], [480, 90], [250, 50], [100, 33], [330, 95],
//                          [410, 12], [475, 44], [25, 67], [85, 21], [220, 88],
//                          [600, 150]
//                        ];

        d3.csv("datatest.csv", function(data) {
        dataset=data
        });



        //Create scale functions
        var xScale = d3.scale.linear()
                             .domain([0, d3.max(dataset, function(d) { return d[0]; })])
                             .range([padding, w - padding * 2]);

        var yScale = d3.scale.linear()
                             .domain([0, d3.max(dataset, function(d) { return d[1]; })])
                             .range([h - padding, padding]);

        var rScale = d3.scale.linear()
                             .domain([0, d3.max(dataset, function(d) { return d[1]; })])
                             .range([2, 5]);

        //Create SVG element
        var svg = d3.select("body")
                    .append("svg")
                    .attr("width", w)
                    .attr("height", h);

        svg.selectAll("circle")
           .data(dataset)
           .enter()
           .append("circle")
           .attr("cx", function(d) {
                return xScale(d[0]);
           })
           .attr("cy", function(d) {
                return yScale(d[1]);
           })
           .attr("r", function(d) {
                return rScale(d[1]);
           });
    </script>
</body>
</html>

CSV ファイルの内容は次のとおりです。

x-coordinate, y-coordinate
5,20
480,90
250,50
100,33
330,95
410,12
475,44
25,67
85,21
220,88
600,150
4

3 に答える 3

15

重要:

ここでの答えは機能しますd3.csv.parseRows()が、同じ結果を達成する組み込みのメソッドがあります。そのためには、@ryanmt の回答 (このページにもあります) を参照してください。ただし、使用する方法に関係なく、CSV に数字が含まれている場合は、それらを文字列から JavaScript の数字に変換する必要があることに注意してください。解析された値の前に+. たとえば、ここで提供したソリューションでは、 を使用せずに、parseRows()を介して変換が行われ+d["x-coordinate"]ます。

答え:

CSV パーサーは、必要な配列の配列ではなく、オブジェクトの配列を生成します。次のようになります。

[
  {"x-coordinate":"5"," y-coordinate":"20"},
  {"x-coordinate":"480"," y-coordinate":"90"},
  {"x-coordinate":"250"," y-coordinate":"50"},
  {"x-coordinate":"100"," y-coordinate":"33"},
  ...
]

map()それを変換するには、関数を使用する必要があります。

d3.csv("datatest.csv", function(data) {
  dataset = data.map(function(d) { return [ +d["x-coordinate"], +d["y-coordinate"] ]; });
});

(注、map()古い IE では使用できません。それが問題になる場合は、d3、jQuery などを使用した回避策がたくさんあります)

于 2013-02-20T18:05:36.050 に答える