我有这个json文件:
{
"Update tree": {
"average time": 0.01610115085649609,
"best time": 0.003310859220941582,
"count": 651,
"success rate": 100,
"worst time": 0.621779361692829
},
"Update renderables": {
"average time": 0.1988377572034353,
"best time": 0.0003510859220941582,
"count": 649,
"success rate": 100,
"worst time": 12.8709652214104
},
"Before render": {
"average time": 0.5206290903024032,
"best time": 0.01522995241633128,
"count": 188,
"success rate": 100,
"worst time": 81.06473259514415
},
"Rendering": {
"average time": 4.425231035278629,
"best time": 0.4979532268296139,
"count": 214,
"success rate": 100,
"worst time": 71.34537426614806
},
"After render": {
"average time": 0.06479598048728916,
"best time": 0.0301288189105684,
"count": 563,
"success rate": 100,
"worst time": 0.6413134310963844
}
}
我要在其中计算每个json对象中所有平均数的平均值的方式如何遍历json对象?
我正在尝试获取所有平均值,并将其求和并计算平均值
编辑:
我有这个for循环,我想遍历每个对象(而不是获取其成员名称,而是实际遍历对象并获取值,然后将其求和):
for(int i=0; i<json.size(); i++){
sumAllAverages(json.getAsJsonObject());
}
private static void sumAllAverages(JsonObject asJsonObject) {
sum += Float.parseFloat(asJsonObject.get("average time").toString());
}
答案 0 :(得分:2)
使用GSON,您可以将其反序列化为如下地图:
Type type = new TypeToken<Map<String, Map<String, Double>>>() {}.getType();
Map<String, Map<String, Double>> map =
new Gson().fromJson(getResourceStreamReader("file.json"), type);
getResourceStreamReader(“ file.json”)只是一个从资源文件获取JSON的辅助方法。它可以是String或任何阅读器。
具有所有平均时间(例如):
Set<Double> averageTimes = map.values().stream()
.map(v -> v.get("average time")).collect(Collectors.toSet());
例如,要检查此地图的平均值,请执行以下操作:
averageTimes.forEach(averageTime -> System.out.println(averageTime));
这将产生:
0.01610115085649609
0.1988377572034353
0.5206290903024032
4.425231035278629
0.06479598048728916
进一步,您可以使用reduce对所有值求和并获得总平均时间;
Double totalAverageTime = averageTimes.stream()
.reduce((a, b) -> a + b).orElse(0D) / averageTimes.size();
检查:
System.out.println(totalAverageTime);
您将看到:
1.0451190028256505
注意:所有这些计算都可以用更少的行数来完成,即使在一个lambda中也是如此,但是为了清楚起见,为了简化操作,我将各阶段进行了划分。
答案 1 :(得分:-1)
这就是我在杰克逊做的方式,gson应该非常相似。
JsonNode time_Data;
try {
time_Data = new ObjectMapper().readTree(jsonTimes); // **this is your file as a string
double sum = 0.0;
if(time_Data!= null) {
for (final JsonNode valuesPacket : time_Data) {
sum += Double.parseDouble(valuesPacket.get("average time").asText());
}
}
System.out.println("sum is :"+sum);
} catch (JsonProcessingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}