- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有这样一个数据集:
CT, CA, GA, TX, Year, Month
1, 1, 2, 4, 2016, 03
2, 1, 3, 5, 2016, 03
状态列下的数字对应于出现的次数。然后我将数据加载到 d3 中,但是如何将数据重新组织为只有 4 列,如下所示:
state, count, year, month
CT, 1, 2016, 03
这是我到目前为止所得到的:
d3.csv("states.csv", function(error, Data){
Data.forEach(function(d){
d.CT = +d.CT;
d.CA = +d.CA;
d.GA = +d.GA;
d.TX = +d.TX;
d.Year = +d.Year;
d.month = +d.month;
});
最佳答案
如果我正确理解了您想要的输出数组,forEach
和 for...in
的组合可以创建它:
var csv = `CT,CA,GA,TX,Year,Month
1,1,2,4,2016,03
2,1,3,5,2016,03`;
var data = d3.csvParse(csv);
var newData = [];
data.forEach(function(d) {
for (var key in d) {
if (key != "Year" && key != "Month") {
newData.push({
state: key,
count: d[key],
year: d.Year,
month: d.Month
})
}
}
});
console.log(newData);
<script src="https://d3js.org/d3.v4.min.js"></script>
由于我无法在堆栈片段中加载真正的 CSV,我将您的示例数据集存储在一个变量中并使用 d3.csvParse
对其进行解析。但是,原理是一样的:只需将该函数放在 d3.csv
回调中即可。
PS:根据您想要的输出示例...
state, count, year, month
CT, 1, 2016, 03
...我假设您不想对具有相同年份和月份的对象求和。如果您真的想对它们求和,请发布另一个问题询问如何做(或进行搜索,因为这是一个常见问题,已经回答)。
关于javascript - d3 热图列标题作为 yaxis,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46714272/
我想要类似于以下伪代码的东西: while input is not None and timer = 5: print "took too long" else: print inp
如何将 MainEngine Observable 转换为 Cold?来自这个例子: public IObservable MainEngine { get
自从手表被发明以来,表盘的方圆之争就始终没有停下来过,在漫长的岁月中,无论是方形还是圆形表盘,人们都为其寻找到足够多的设计元素,让其肆意成长,这种生机与活力后来也延续到了智能手表上,在2014年,这
我正在学习 CUDA,试图解决一些标准问题。例如,我正在使用以下代码求解二维扩散方程。但我的结果与标准结果不同,我无法弄清楚。 //kernel definition __global__ void
我的 Web 应用程序使用 native dll 来实现其部分功能(其位置在 PATH 中提供)。一切正常,直到我对 WAR 进行更改并且 JBoss 热部署此 WAR。此时dll已经找不到了,需要手
我看到这个问题here 。这是关于实现每个发出的项目的延迟。这是根据accepted answer如何实现的: Observable.zip(Observable.range(1, 5) .g
我最近一直在进行冷迁移...这意味着我无法在进行迁移时从应用程序级别读取/写入数据库(维护页面)。 这样就不会因为更改结构而发生错误,而且如果负载很大,我也不希望 mysql 在迁移过程中崩溃。 我的
我是一名优秀的程序员,十分优秀!