#python #list #dictionary #nested
Вопрос:
У меня есть словарь, который содержит данные для пунктов обмена
points = {
1:{'name': 'ТОО ARS', 'address': 'str. 10А', 'rates': [{'currency': 'No Data', 'bid': 'No Data', 'ask': 'No Data'}], 'lat': 43.215702, 'lng': 76.860278, 'distance': 459, 'point_id': 10},
2:{'name': 'ТОО REAL EXCHANGE', 'address': 'ave. 10', 'rates': [{'currency': 'EUR', 'bid': 519.3, 'ask': 521.2}], 'lat': 43.218291, 'lng': 76.866234, 'distance': 915, 'point_id': 8},
3:{'name': 'ТОО REAL EXCHANGE', 'address': 'ave. 10', 'rates': [{'currency': 'USD', 'bid': 430.0, 'ask': 432.0}], 'lat': 43.218291, 'lng': 76.866234, 'distance': 915, 'point_id': 8},
4:{'name': 'ТОО REAL EXCHANGE', 'address': 'ave. 10', 'rates': [{'currency': 'TRY', 'bid': 86.0, 'ask': 88.0}], 'lat': 43.218291, 'lng': 76.866234, 'distance': 915, 'point_id': 8},
5:{'name': 'ТОО REAL EXCHANGE', 'address': 'ave. 10', 'rates': [{'currency': 'KGS', 'bid': 6.0, 'ask': 8.0}], 'lat': 43.218291, 'lng': 76.866234, 'distance': 915, 'point_id': 8},
6:{'name': 'ТОО ARS', 'address': 'str. 10А', 'rates': [{'currency': 'KGS-2', 'bid': 6.0, 'ask': 8.0}], 'lat': 43.215702, 'lng': 76.860278, 'distance': 360, 'point_id': 10},
}
как я могу получить новый словарь, например
new_dict = {10: {'name': 'ТОО ARS',
'address': 'str. 10А',
'rates': [{'currency': 'No Data', 'bid': 'No Data', 'ask': 'No Data'},{'currency': 'KGS-2', 'bid': 6.0, 'ask': 8.0}]},
8: {'name': 'ТОО REAL EXCHANGE',
'address': 'ave. 10',
'rates': [{'currency': 'EUR', 'bid': 519.3, 'ask': 521.2},
{'currency': 'USD', 'bid': 430.0, 'ask': 432.0},
{'currency': 'TRY', 'bid': 86.0, 'ask': 88.0},
{'currency': 'KGS', 'bid': 6.0, 'ask': 8.0}]}}
Я пытался, как
points = {
1:{'name': 'ТОО ARS', 'address': 'str. 10А', 'rates': [{'currency': 'No Data', 'bid': 'No Data', 'ask': 'No Data'}], 'lat': 43.215702, 'lng': 76.860278, 'distance': 459, 'point_id': 10},
2:{'name': 'ТОО REAL EXCHANGE', 'address': 'ave. 10', 'rates': [{'currency': 'EUR', 'bid': 519.3, 'ask': 521.2}], 'lat': 43.218291, 'lng': 76.866234, 'distance': 915, 'point_id': 8},
3:{'name': 'ТОО REAL EXCHANGE', 'address': 'ave. 10', 'rates': [{'currency': 'USD', 'bid': 430.0, 'ask': 432.0}], 'lat': 43.218291, 'lng': 76.866234, 'distance': 915, 'point_id': 8},
4:{'name': 'ТОО REAL EXCHANGE', 'address': 'ave. 10', 'rates': [{'currency': 'TRY', 'bid': 86.0, 'ask': 88.0}], 'lat': 43.218291, 'lng': 76.866234, 'distance': 915, 'point_id': 8},
5:{'name': 'ТОО REAL EXCHANGE', 'address': 'ave. 10', 'rates': [{'currency': 'KGS', 'bid': 6.0, 'ask': 8.0}], 'lat': 43.218291, 'lng': 76.866234, 'distance': 915, 'point_id': 8},
6:{'name': 'ТОО ARS', 'address': 'str. 10А', 'rates': [{'currency': 'KGS-2', 'bid': 6.0, 'ask': 8.0}], 'lat': 43.215702, 'lng': 76.860278, 'distance': 360, 'point_id': 10},
}
new_dict={}
test_keys=[]
z=0
rates=[]
for i in points:
test_keys.append(points[i]['point_id'])
for key in range(len(test_keys)-1):
if test_keys[key 1] == test_keys[key]:
test_keys.remove(test_keys[key 1])
for keys in test_keys:
new_dict[keys] = ''
for i in new_dict:
for j in points:
if i == points[j]['point_id']:
name = points[j]['name']
address = points[j]['address']
new_dict[i] = {'name':points[j]['name'], 'address':address, 'rates': rates}
for i in range(1,len(points)):
if points[i]['point_id'] in new_dict:
kurs = points[i]['rates'][0]
exchange_point_id = points[i]['point_id']
for j in new_dict.keys():
if exchange_point_id == j:
z =1
if z>1:
rates.append(kurs)
new_dict[j]['rates'] = rates
elif z<=1:
new_dict[j]['rates'] = kurs
и это не работает
результат, который я получаю, таков:
{10: {'name': 'ТОО ARS',
'address': 'str. 10А',
'rates': {'currency': 'No Data', 'bid': 'No Data', 'ask': 'No Data'}},
8: {'name': 'ТОО REAL EXCHANGE',
'address': 'ave. 10',
'rates': [{'currency': 'EUR', 'bid': 519.3, 'ask': 521.2},
{'currency': 'USD', 'bid': 430.0, 'ask': 432.0},
{'currency': 'TRY', 'bid': 86.0, 'ask': 88.0},
{'currency': 'KGS', 'bid': 6.0, 'ask': 8.0}]}}
Ответ №1:
Вы просто хотите сгруппировать элементы с одинаковым идентификатором point_id?
from pprint import pprint
points = {
1:{'name': 'ТОО ARS', 'address': 'str. 10А', 'rates': [{'currency': 'No Data', 'bid': 'No Data', 'ask': 'No Data'}], 'lat': 43.215702, 'lng': 76.860278, 'distance': 459, 'point_id': 10},
2:{'name': 'ТОО REAL EXCHANGE', 'address': 'ave. 10', 'rates': [{'currency': 'EUR', 'bid': 519.3, 'ask': 521.2}], 'lat': 43.218291, 'lng': 76.866234, 'distance': 915, 'point_id': 8},
3:{'name': 'ТОО REAL EXCHANGE', 'address': 'ave. 10', 'rates': [{'currency': 'USD', 'bid': 430.0, 'ask': 432.0}], 'lat': 43.218291, 'lng': 76.866234, 'distance': 915, 'point_id': 8},
4:{'name': 'ТОО REAL EXCHANGE', 'address': 'ave. 10', 'rates': [{'currency': 'TRY', 'bid': 86.0, 'ask': 88.0}], 'lat': 43.218291, 'lng': 76.866234, 'distance': 915, 'point_id': 8},
5:{'name': 'ТОО REAL EXCHANGE', 'address': 'ave. 10', 'rates': [{'currency': 'KGS', 'bid': 6.0, 'ask': 8.0}], 'lat': 43.218291, 'lng': 76.866234, 'distance': 915, 'point_id': 8},
6:{'name': 'ТОО ARS', 'address': 'str. 10А', 'rates': [{'currency': 'KGS-2', 'bid': 6.0, 'ask': 8.0}], 'lat': 43.215702, 'lng': 76.860278, 'distance': 360, 'point_id': 10},
}
new_dict = {}
for point in points.values():
point_id = point["point_id"]
if point_id in new_dict:
new_dict[point_id]["rates"].extend(point["rates"])
else:
new_dict[point_id] = point.copy()
new_dict[point_id].pop("point_id")
pprint(new_dict)
Выход:
{8: {'address': 'ave. 10',
'distance': 915,
'lat': 43.218291,
'lng': 76.866234,
'name': 'ТОО REAL EXCHANGE',
'rates': [{'ask': 521.2, 'bid': 519.3, 'currency': 'EUR'},
{'ask': 432.0, 'bid': 430.0, 'currency': 'USD'},
{'ask': 88.0, 'bid': 86.0, 'currency': 'TRY'},
{'ask': 8.0, 'bid': 6.0, 'currency': 'KGS'}]},
10: {'address': 'str. 10А',
'distance': 459,
'lat': 43.215702,
'lng': 76.860278,
'name': 'ТОО ARS',
'rates': [{'ask': 'No Data', 'bid': 'No Data', 'currency': 'No Data'},
{'ask': 8.0, 'bid': 6.0, 'currency': 'KGS-2'}]}}
Комментарии:
1. О, спасибо вам за ваш комментарий. На самом деле я хотел бы сгруппировать элемент с одинаковым идентификатором point_id. да