根据内部数组值跳过 JSON 数据记录 - D3
skipping JSON data records based on inner array values- D3
我的数据如下。
data=[ {"venue":"Foyer","values":[{"avg":996.8,"sessions":[{"minTime":0,"maxTime":599,"count":50},
{"minTime":600,"maxTime":1199,"count":39},
{"minTime":1800,"maxTime":2399,"count":43},
{"minTime":2400,"maxTime":2999,"count":48}],"timestamp":1449360000},
{"avg":986.4,"sessions":[{"minTime":0,"maxTime":599,"count":152},
{"minTime":600,"maxTime":1199,"count":51},
{"minTime":1200,"maxTime":1799,"count":36},
{"minTime":1800,"maxTime":2399,"count":68},
{"minTime":3000,"maxTime":3599,"count":34}],"timestamp":1452540000}]},
{"venue":"Venue1","values":[{"avg":996.8,"sessions":[{"minTime":0,"maxTime":599,"count":62},
{"minTime":600,"maxTime":1199,"count":33},
{"minTime":1800,"maxTime":2399,"count":37},
{"minTime":2400,"maxTime":2999,"count":24}],"timestamp":1449360000},
{"avg":986.4,"sessions":[{"minTime":0,"maxTime":599,"count":34},
{"minTime":600,"maxTime":1199,"count":52},
{"minTime":1200,"maxTime":1799,"count":21},
{"minTime":1800,"maxTime":2399,"count":142},
{"minTime":3000,"maxTime":3599,"count":23}],"timestamp":1452540000}]},
{"venue":"Venue2","values":[{"avg":996.8,"sessions":[{"minTime":0,"maxTime":599,"count":44},
{"minTime":600,"maxTime":1199,"count":25},
{"minTime":1800,"maxTime":2399,"count":34},
{"minTime":2400,"maxTime":2999,"count":23}],"timestamp":1449360000},
{"avg":986.4,"sessions":[{"minTime":0,"maxTime":599,"count":31},
{"minTime":600,"maxTime":1199,"count":11},
{"minTime":1200,"maxTime":1799,"count":122},
{"minTime":1800,"maxTime":2399,"count":12},
{"minTime":3000,"maxTime":3599,"count": 3}],"timestamp":1452540000}]}]
我想从"值"中过滤记录,仅具有匹配的时间戳。应过滤不匹配时间戳的"值"中的条目,但输出应具有相同的数据结构,
预期输出:
[{"venue":"Foyer","values":[{"avg":996.8,"sessions":[{"minTime":0,"maxTime":599,"count":50},
{"minTime":600,"maxTime":1199,"count":39},
{"minTime":1800,"maxTime":2399,"count":43},
{"minTime":2400,"maxTime":2999,"count":48}],"timestamp":1449360000}]},
{"venue":"Venue1","values":[{"avg":996.8,"sessions":[{"minTime":0,"maxTime":599,"count":62},
{"minTime":600,"maxTime":1199,"count":33},
{"minTime":1800,"maxTime":2399,"count":37},
{"minTime":2400,"maxTime":2999,"count":24}],"timestamp":1449360000}]},
{"venue":"Venue2","values":[{"avg":996.8,"sessions":[{"minTime":0,"maxTime":599,"count":44},
{"minTime":600,"maxTime":1199,"count":25},
{"minTime":1800,"maxTime":2399,"count":34},
{"minTime":2400,"maxTime":2999,"count":23}],"timestamp":1449360000}]}]
我已经尝试使用以下代码,但只出现了最后一个场地(venue2)。
法典:
d3.json("Dwell.json", function(error,data){
data.forEach(function(a) {
resultfilter={ "venue": a.venue, "values":a.values.filter(function (d) { return d.timestamp = 1449360000 } ) }
})
document.write('<pre>' + JSON.stringify(resultfilter) + '</pre>');
这是因为您在每次运行forEach
调用时都会覆盖resultfilter
。您可能希望在首次初始化 resultfilter
数组后在每个 forEach
循环中执行类似 resultfilter.push( <FILTER RESULT>)
的操作。像这样:
resultfilter = [];
data.forEach(function(a) {
resultfilter.push(...);
})
(另外,看起来您复制的data
对象存在一些问题。如果它与复制/粘贴到这个问题中无关,那么也给它一个检查)
可以使用Array.prototype.map()
来简化此操作
var resultfilter = data.map(function(item) {
item.values = item.values.filter(function(d) {
return d.timestamp = 1449360000
});
return item;
});
相关文章:
- 无法使用变量访问数据 JSON
- 使用 ng-repeat解析不均匀数据/ json对象
- 在没有jsonp的情况下从另一个域获取数据(json格式)
- 如何获取带参数的数据json
- 如何在android中显示实时雅虎金融股票数据..json格式如下所示
- 使用 JavaScript 将数据 json 显示到网页中
- 高位图表来源于API数据(JSON)
- 使用动态数据json初始化同位素
- Django:将数据JSON从视图传递给javascript
- 存储配置数据 (json)
- 未捕获的SyntaxError:意外的标识符图像数据json
- 接收数据json/jquery
- Jquery数据表数据json
- 不能在cakephp中使用数组数据json
- 在不锁定浏览器的情况下,将大数据JSON从REST请求反序列化为对象
- 如何读取数据JSON格式数组的字符串数据
- 我有一个流星应用程序,需要从/public/_assets/results/mmresults读取数据.Json文件,在
- 数据json不显示在html
- 使用2个下拉列表创建2个并排的表行来比较数据- JSON
- 需要将复杂的json对象转换为合适的angularjs UI树数据json结构