d3.csv()后获取的数据不是数组,而是对象

更新日期: 2019-04-23 阅读: 4.1k 标签: d3

我的csv文件:

year,population
1953,5.94
1964,6.95
1982,10.08
1990,11.34
2000,12.66
2010,13.40

使用d3.csv()输出:

d3.csv("Data/data.csv",function (error,data) {
    if(error){
        console.log(error)
    }
    console.log(data);
    return data;
})

可以看到并不是csv数组。


解决方法1:

查看官方api文档(https://github.com/d3/d3-fetch/blob/master/README.md#dsv):

修改代码如下:

d3.csv("Data/data.csv",function (csvdata) {
    console.log(csvdata);
    return csvdata;
}).then(function (data) {
    console.log(data)
})

输出:


解决方法2:

使用d3.dsv(),代码并格式化数据如下:

d3.dsv(",", "Data/data.csv", function(d) {
    return {
        year: new Date(+d.year, 0, 1), // convert "Year" column to Date
        population: +d.population // convert "population" column to number
    };
}).then(function(data) {
    console.log(data);
});

输出:

本文内容仅供个人学习/研究/参考使用,不构成任何决策建议或专业指导。分享/转载时请标明原文来源,同时请勿将内容用于商业售卖、虚假宣传等非学习用途哦~感谢您的理解与支持!

链接: https://fly63.com/article/detial/3027

在Vue项目里面使用d3.js

在Vue里面使用D3.js的方法,npm 上面的D3相对来说 可以说是很不人性化了 完全没有说 在webpack上怎么使用D3.js,将视图从逻辑中分离出来,并且使用Vue钩子,方法和data对象。

d3.js使用svg

相比HTML元素,使用SVG可以绘制出更多的图形,此文尝试将d3.js与SVG结合 由于我也是第一次使用SVG,所以主要根据此篇blog的顺序来Let’s Make a Bar Chart, II用于组合对象的容器,添加到g元素上的变换会应用到所有子元素上

D3.js 对角线生成器 (V3版本)

对角线生成器(Diagonal Generator)用于将两个点连接起来,连接线是三次贝塞尔曲线,该生成器使用d3.svg.diagonal()创建。有两个访问器,source()和target(),还有一个投影函数projection(),用于将坐标进行投影。

d3.js制作连线动画图和编辑器

本项目使用主要d3.jsv4制作,分两部分,一个是实际展示的连线动画图,另一个是管理人员使用鼠标编辑连线的页面。对于d3.js如何引入图片,如何画线等基础功能,这里就不再介绍了,大家可以找一些入门文章看一下。这里主要介绍一下重点问题

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!