我有一组数据如下所示:
#API name, min, max, average
['findProductByPartNumber', '336.0', '336.0', '336.0']
['findProductByPartNumber', '336.0', '339.0', '337.5']
['findProductByPartNumber', '336.0', '339.0', '338.0']
['findProductByPartNumber', '336.0', '341.0', '338.75']
['findProductByPartNumber', '336.0', '353.0', '341.6']
['findProductById', '841.0', '841.0', '841.0']
['findProductByPartNumber', '336.0', '920.0', '438.0']
['findProductByPartNumber', '336.0', '944.0', '510.29']
['findProductByPartNumber', '336.0', '952.0', '565.5']
['findProductByPartNumber', '336.0', '975.0', '611.0']
['findProductsByCategory', '113.0', '113.0', '113.0']
['findProductById', '161.0', '841.0', '501.0']
['findProductByPartNumber', '255.0', '975.0', '575.4']
我要做的是,对于每个单独的API,生成如下内容:
API, Min, Max, Average, 90th Percentile
findProductByPartNumber, 278.69, 770.25, 458.69, 565.5
findProductById, 373.0, 841.0, 571.67, 501.0
findProductsByCategory, 112.33, 187.17, 154.46, 167.75
这是上面每个API的聚合结果。在Python中,最好的方法是什么?你知道吗
编辑:
我有下面的Java代码什么做我想要的。Java是我最好的语言,我正在努力学习Python,我对数据结构不熟悉。你知道吗
double[] apiValues = new double[3];
apiValues[0] = Double.valueOf(min);
apiValues[1] = Double.valueOf(max);
apiValues[2] = Double.valueOf(average);
parseAPILogs.registerAPI(name, apiValues);
...
...
private static void registerAPI(String apiName, double[] apiValues) {
if(!averagePerAPI.containsKey(apiName)) {
APIData data = new APIData();
data.addValues(apiValues);
averagePerAPI.put(apiName, data);
} else {
averagePerAPI.get(apiName).addValues(apiValues);
}
}
apidatajava类在这里有点大,但您可以看到我的想法。你知道吗
这样怎么样:
输出
至于第90百分位,如果没有单独的样本是不可能计算的,除非你只使用.9*平均值
相关问题 更多 >
编程相关推荐