python - 格式化数据点列表以显示在图表中
问题描述
我正在 Django Rest Framework 中编写 API 端点,并希望为图形格式化数据。我有这样的数据,我从数据库中获得:
data = [
{
"name": "Test 3",
"status": "Active",
"count": 1
},
{
"name": "Test 2",
"status": "Failed",
"count": 1
},
{
"name": "Test",
"status": "In Progress",
"count": 85
},
{
"name": "Test",
"status": "Failed",
"count": 40
},
{
"name": "Test",
"status": "Active",
"count": 1
},
{
"name": "Test",
"status": "Success",
"count": 218
},
{
"name": "Test 2",
"status": "Active",
"count": 1
}
]
我想像这样格式化上面的最终图形数据,以便在图形中显示它:
[
"labels": ['Test', 'Test 2', 'Test 3'],
"data": [
{
name: 'Active',
data: [1, 1, 1]
},
{
name: 'Failed',
data: [40, 1, 0]
},
{
name: 'Success',
data: [218, 0, 0]
},
{
name: 'In Progress',
data: [85, 0, 0]
}
]
]
我正在尝试以这种方式格式化数据,但我无法这样做。是否有任何内置函数可用于使数据格式正确?
response = [
{
'labels': [],
'data': [],
}
]
for row in data:
if row['name'] not in response[0]['labels']:
response[0]['labels'].append(row['name'])
innerData = []
for status in ['Active', 'Failed', 'Success', 'In Progress']:
if status in row['status']:
innerData.append(row['count'])
else:
innerData.append(0)
response[0]['data'].append(
{
'name': status,
'data': innerData,
}
)
解决方案
基于 Rustam 的回答:
- Add a dictionary
label_to_idx
to be used to determine the index by label. - Pass a
lambda
function todefaultdict
to initialize lists of correct size and default value. - Populate
d
for each status, usinglabel_to_idx
to find the correct index to fill with count.
from collections import defaultdict
data = [
{"name": "Test 3", "status": "Active", "count": 1},
{"name": "Test 2", "status": "Failed", "count": 1},
{"name": "Test", "status": "In Progress", "count": 85},
{"name": "Test", "status": "Failed", "count": 40},
{"name": "Test", "status": "Active", "count": 1},
{"name": "Test", "status": "Success", "count": 218},
{"name": "Test 2", "status": "Active", "count": 1},
]
labels = sorted({each['name'] for each in data})
label_to_idx = {label: idx for idx, label in enumerate(labels)} # Added
d = defaultdict(lambda: [0] * len(labels)) # Modified
for each in data:
d[each['status']][label_to_idx[each['name']]] = each['count'] # Modified
final_result = {'labels': labels, 'data': []}
for k, v in d.items():
final_result['data'].append({'name': k, 'data': v})
from pprint import pprint as pp
pp(final_result)
# {'data': [{'data': [1, 1, 1], 'name': 'Active'},
# {'data': [40, 1, 0], 'name': 'Failed'},
# {'data': [85, 0, 0], 'name': 'In Progress'},
# {'data': [218, 0, 0], 'name': 'Success'}],
# 'labels': ['Test', 'Test 2', 'Test 3']}
推荐阅读
- node.js - 是什么导致在docker中使用节点出现以下错误
- php - PDO $_GET 当用户单击该任务的删除按钮时删除数据库中特定任务的任务ID
- python - Plotly:如何为具有完全不同数据和布局的图形制作一个绘图下拉菜单?
- performance - sqlalchemy 延迟列加载 - 似乎没有任何效率
- html - css 中的 SVG Sprite 声明的背景图像
- javascript - 通过循环从另一个数组在js中创建多维数组
- c++ - 在c ++中查找两个括号之间的字符串,省略里面的其他括号
- javascript - 在纯函数中使用像 Object.keys() 这样的全局函数会被合理地视为杂质吗?
- apache-spark - 如果在低内存上运行,Spark 会比 Hadoop MapReduce 表现更好吗?
- reactjs - 来自不同组件的 react-facebook-pixel