¿Hay alguna forma en Python 2.6 para suministrar una clave personalizada o una función cmp a sort_keys de JSON?pedido JSON sort_keys personalizado en Python
Tengo una lista de dicts procedentes de JSON de este modo:
[
{
"key": "numberpuzzles1",
"url": "number-puzzle-i.html",
"title": "Number Puzzle I",
"category": "nestedloops",
"points": "60",
"n": "087"
},
{
"key": "gettingindividualdigits",
"url": "getting-individual-digits.html",
"title": "Getting Individual Digits",
"category": "nestedloops",
"points": "80",
"n": "088"
}
]
... lo que me he guardado en la variable de lista assigndb
. Me gustaría poder cargar en el JSON, modificarlo y serializarlo de nuevo con dumps
(o lo que sea), manteniendo intactos los pedidos de las claves .
Hasta ahora, he intentado algo como esto:
ordering = {'key': 0, 'url': 1, 'title': 2, 'category': 3,
'flags': 4, 'points': 5, 'n': 6}
def key_func(k):
return ordering[k]
# renumber assignments sequentially
for (i, a) in enumerate(assigndb):
a["n"] = "%03d" % (i+1)
s = json.dumps(assigndb, indent=2, sort_keys=True, key=key_func)
... pero por supuesto dumps
no es compatible con una clave personalizada como list.sort()
hace. Algo con una costumbre JSONEncoder
tal vez? Parece que no puedo hacerlo funcionar.
Feo, pero funcional; ¡Gracias! –