Como json.loads
simplemente devuelve un diccionario, puede utilizar los operadores que se aplican a dicts:
>>> jdata = json.load('{"uri": "http:", "foo", "bar"}')
>>> 'uri' in jdata # Check if 'uri' is in jdata's keys
True
>>> jdata['uri'] # Will return the value belonging to the key 'uri'
u'http:'
Editar: para dar una idea sobre la forma de bucle a través de los datos, consideremos el siguiente ejemplo:
>>> import json
>>> jdata = json.loads(open ('bookmarks.json').read())
>>> for c in jdata['children'][0]['children']:
... print 'Title: {}, URI: {}'.format(c.get('title', 'No title'),
c.get('uri', 'No uri'))
...
Title: Recently Bookmarked, URI: place:folder=BOOKMARKS_MENU(...)
Title: Recent Tags, URI: place:sort=14&type=6&maxResults=10&queryType=1
Title: , URI: No uri
Title: Mozilla Firefox, URI: No uri
Inspección de la estructura de datos jdata
le permitirá navegar a tu gusto. La llamada pprint
que ya tiene es un buen punto de partida para esto.
Edit2: Otro intento. Esto obtiene el archivo que mencionaste en una lista de diccionarios. Con esto, creo que deberías poder adaptarlo a tus necesidades.
>>> def build_structure(data, d=[]):
... if 'children' in data:
... for c in data['children']:
... d.append({'title': c.get('title', 'No title'),
... 'uri': c.get('uri', None)})
... build_structure(c, d)
... return d
...
>>> pprint.pprint(build_structure(jdata))
[{'title': u'Bookmarks Menu', 'uri': None},
{'title': u'Recently Bookmarked',
'uri': u'place:folder=BOOKMARKS_MENU&folder=UNFILED_BOOKMARKS&(...)'},
{'title': u'Recent Tags',
'uri': u'place:sort=14&type=6&maxResults=10&queryType=1'},
{'title': u'', 'uri': None},
{'title': u'Mozilla Firefox', 'uri': None},
{'title': u'Help and Tutorials',
'uri': u'http://www.mozilla.com/en-US/firefox/help/'},
(...)
}]
A continuación "buscar a través de él para u'uri': u'http:'
", hacer algo como esto:
for c in build_structure(jdata):
if c['uri'].startswith('http:'):
print 'Started with http'
Se", línea 3, en ValueError: nombre de campo de longitud cero en el formato cuando trato de iniciar el segundo ejemplo –
BKovac
Eso probablemente esté relacionado con el diseño de los marcadores que exportó ... Realmente no conozco el formato, pero supongo que crea una clave 'children' para cada carpeta o contenedor que tengas en tus marcadores. Pruébelo, por ejemplo, con 'for c in jdata ['children']:' en lugar de lo anterior. Además, tenga en cuenta que la función ''{}'. Format()' es nueva en Python 2.6 ... es posible que tenga una versión anterior. Si es así, reemplace esa línea con 'print' Título:% s, URI:% s '% (c.get (' título ',' Sin título '), c.get (' uri ',' No uri ')) '. – jro
Todavía no funciona Aquí está el archivo de bookmakrs http://pastebin.com/uCtECvDi – BKovac