Доступ к различным парам ключ / значение JSON в понимании списка - PullRequest
0 голосов
/ 18 декабря 2018

Не уверен, пытаюсь ли я достичь невозможного?У меня есть эта строка JSON:

dot= [{"type": 1, "date": "2018-12-02T00:40:03.2186792+00:00", "device": 
[{"id": "20165cf4e596", "deviceName": "17", "records": [{"timestamp": "2018- 
12-02T00:40:00.499+00:00", "grp": "undefined", "val": 887}]}, {"id": 
"5f401a6a6f66", "deviceName": "18", "records": [{"timestamp": "2018-12- 
02T00:42:00.499+00:00", "grp": "undefined", "val": 1063}, {"timestamp": 
"2018-12-02T00:41:00.498+00:00", "grp": "undefined", "val": 907}]}, {"id": 
"569bb0147a72", "deviceName": "19", "records": [{"timestamp": "2018-12- 
02T00:44:00.499+00:00", "grp": "undefined", "val": 817}, {"timestamp": 
"2018-12-02T00:43:00.498+00:00", "grp": "undefined", "val": 1383}]}, {"id": 
"ef829aa3", "deviceName": "2", "records": [{"timestamp": "2018-12- 
02T00:46:00.499+00:00", "grp": "undefined", "val": 1173}]}, {"id": 
"388ae8f2fa64", "deviceName": "17", "records": [{"timestamp": "2018-12- 
02T00:41:00.499+00:00", "grp": "undefined", "val": 866}, {"timestamp": 
"2018-12-02T00:32:00.492+00:00", "grp": "undefined", "val": 1080}]}, {"id": 
"01f874b30b55", "deviceName": "19", "records": [{"timestamp": "2018-12- 
02T00:43:00.499+00:00", "grp": "undefined", "val": 1050}, {"timestamp": 
"2018-12-02T00:42:00.498+00:00", "grp": "undefined", "val": 1084}]}]}]

И я хочу добиться следующего:

[{'id': '20165cf4e596','deviceName': '17','timestamp': '2018-12- 
02T00:40:00.499+00:00','grp': 'undefined','val': 887},
{'id': '5f401a6a6f66','deviceName': '18','timestamp': '2018-12- 
02T00:42:00.499+00:00','grp': 'undefined','val': 1063},
{'id': '5f401a6a6f66','deviceName': '18','timestamp': '2018-12- 
02T00:41:00.498+00:00','grp': 'undefined','val': 907},...]

Я использовал следующий код:

for i in dot:
    for k in i['device']:
        d2= [[{l:m},{'value':v}] for l,m in k.items() for p in m if 
        isinstance(p,list) for v in p]
        print(d2)

И получил пустойсписки:

[]
[]
[]
[]

Заранее спасибо

Ответы [ 2 ]

0 голосов
/ 18 декабря 2018

Ответ Бармара может быть правильным - но я полагаю, вам будет намного легче, если вы деобфусцируете свой код, создав иерархию объектов, которые представляют элементы в вашей структуре данных:

class SomeObject:
    def __init__(self, some_object_type, date, devices):
        self.type = some_object_type
        self.date = date
        self.devices = []

        for d in devices:
            some_device = SomeDevice(d["id"], d["deviceName"], d["records"])
            self.devices.append(some_device)

class SomeDevice:
    def __init__(self, some_device_id, name, records):
        self.id = some_device_id
        self.name = name
        self.records = []

        for r in records:
            some_record = SomeDeviceRecord(r["timestamp"], r["grp"], r["val"])
            self.records.append(some_record)

class SomeDeviceRecord:
    def __init__(self, timestamp, group, value):
        self.timestamp = timestamp
        self.group = group
        self.value = value

Если вы пойдете по этому пути, вы можете легко разобрать весь JSON в строго типизированные объекты:

some_object = SomeObject(dot[0]["type"], dot[0]["date"], dot[0]["device"])

И тогда будет достаточно просто / просто отчитаться по отдельным частям структуры данных:

for device in some_object.devices:
    print(device.id, device.name, device.records[0].timestamp, device.records[0].group, device.records[0].value)
0 голосов
/ 18 декабря 2018

Вам нужно перебрать элемент records каждого устройства.Затем объедините поля устройства с каждой записью.

result = []
for i in dot:
    for k in i['device']:
        for r in k['records']:
            result.append({"id": k["id"], "deviceName": k["deviceName"], "timestamp": r["timestamp"], "grp": r["grp"], "val": r["val"]})
print(result)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...