Попытка чтения внутреннего ключа, значения из Unicode JSON в Python - PullRequest
0 голосов
/ 08 октября 2018

Я пытаюсь получить значение ключа снизу Юникод JSON это python

messagejson={
u'Records': 
[
{
u'requestParameters': {u'sourceIPAddress': u'113.112.10.06'}, 
u'sql': {u'configurationId': u'note', 
u'object': {u'eTag': u'ed3645fa5ee', u'sequencer': u'005', u'key': u'src-1.txt', u'size': 606}, 
u'mysql': {u'dn': u'url', u'name': u'invoice',
u'ownerIdentity': {u'principalId': u'A3UJ54'}
}, 
u'myval': u'1.0'
}, 
u'ee': {u'abc': u'tcCh6T', u'x': u'487DBE36E1'}, 
u'userIdentity': {u'principalId': u'AWS:AIDAIOJ4'}, 
u'eventSource': u'source'
}
]
}

Пробовал с помощью

print messagejson['Records'][0]['sql']['key']

Ошибка получения

TypeError: list indices must be integers, not str

может кто-нибудь помочь

Ответы [ 2 ]

0 голосов
/ 08 октября 2018

Вам не хватает одного уровня в вашем диктовке.

Запустите это, и вы увидите.

print messagejson['Records'][0]['sql']

Ключ находится в пределах значения ключа объекта, поэтому вам нужно добавить «объект», прежде чем вы получите «ключ»

print messagejson['Records'][0]['sql']['object']['key']
0 голосов
/ 08 октября 2018

Вам не хватает уровня object в индексировании:

messagejson['Records'][0]['sql']['object']['key']
# src-1.txt
...