Glom упрощает доступ к сложным вложенным структурам данных.
https://github.com/mahmoud/glom
Учитывая следующую игрушечную структуру данных:
target = [
{
'user_id': 198,
'id': 504508,
'first_name': 'John',
'last_name': 'Doe',
'active': True,
'email_address': 'jd@test.com',
'new_orders': False,
'addresses': [
{
'location': 'home',
'address': 300,
'street': 'Fulton Rd.'
}
]
},
{
'user_id': 209,
'id': 504508,
'first_name': 'Jane',
'last_name': 'Doe',
'active': True,
'email_address': 'jd@test.com',
'new_orders': True,
'addresses': [
{
'location': 'home',
'address': 251,
'street': 'Maverick Dr.'
},
{
'location': 'work',
'address': 4532,
'street': 'Fulton Cir.'
},
]
},
]
Я пытаюсь извлечь все поля адреса в структуре данных в единый список словарей.
from glom import glom as glom
from glom import Coalesce
import pprint
"""
Purpose: Test the use of Glom
"""
# Create Glomspec
spec = [{'address': ('addresses', 'address') }]
# Glom the data
result = glom(target, spec)
# Display
pprint.pprint(result)
Приведенная выше спецификация обеспечивает:
[
{'address': [300]},
{'address': [251]}
]
Желаемый результат:
[
{'address':300},
{'address':251},
{'address':4532}
]
Какой Glomspec выдаст желаемый результат?