首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >d3 csv数据加载

d3 csv数据加载
EN

Stack Overflow用户
提问于 2013-02-21 01:42:13
回答 2查看 71.1K关注 0票数 17

我正在尝试在D3中修改一个简单的散点图程序来接受CSV文件。当我使用文件中的数据时,它工作得很好,但当我试图加载CSV文件时,它就不能工作了。我是不是遗漏了什么简单的东西?CSV文件"datatest.csv“的内容与代码中的数据集相同。我已经检查到浏览器正在加载数据,而且似乎都在那里。我想我只是漏掉了一步。

代码语言:javascript
复制
<!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文件的内容:

代码语言:javascript
复制
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
EN

回答 2

Stack Overflow用户

发布于 2014-02-22 02:03:21

D3为这件事提供了一个内置的东西。

调用.parseRows,而不是对数据调用.parse()。这只将数据作为Array提供,而不是Object (基于标题行)。

请参阅Documentation

票数 7
EN

Stack Overflow用户

发布于 2018-08-07 15:44:16

使用d3.csvParseRow(假设D3 v5)

代码语言:javascript
复制
d3.text('/data/output.csv')
  .then( text => d3.csvParseRows(text) )
  .then( d => console.log(d) );
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/14986435

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档