Read the JSON from the file and convert it to a dictionary. Use a list comprehension to generate a list of dictionaries and write that out as a JSON list:
import json
with open('file.json') as infile, open('out.json', 'w') as outfile:
d = json.load(infile)
json.dump([{'word': k, 'transcription': d[k]} for k in d], outfile)
For your input file this will produce an output file containing:
[{"transcription": "\u0259b\u00e6\u0283", "word": "abash"}, {"transcription": "\u0259briviet", "word": "abbreviate"}, {"transcription": "abaft", "word": "abaft"}, {"transcription": "a1", "word": "A1"}, {"transcription": "\u0259b\u00e6nd\u0259nd", "word": "abandoned"}, {"transcription": "\u0259b\u00e6nd\u0259nm\u0259nt", "word": "abandonment"}, {"transcription": "\u0259betm\u0259nt", "word": "abatement"}, {"transcription": "\u0259bet", "word": "abate"}, {"transcription": "\u0259b\u00e6nd\u0259n", "word": "abandon"}, {"transcription": "\u00e6bi", "word": "abbey"}, {"transcription": "\u0259brivie\u0283\u0259n", "word": "abbreviation"}, {"transcription": "\u0259b\u00e6k", "word": "aback"}, {"transcription": "abase", "word": "abase"}, {"transcription": "abashment", "word": "abashment"}]
You can format the output a bit, use indent:
json.dump([{'word': k, 'transcription': d[k]} for k in d], outfile, indent='')
will output:
[
{
"word": "aback",
"transcription": "\u0259b\u00e6k"
},
{
"word": "abandonment",
"transcription": "\u0259b\u00e6nd\u0259nm\u0259nt"
},
{
"word": "abatement",
"transcription": "\u0259betm\u0259nt"
},
{
"word": "abbey",
"transcription": "\u00e6bi"
},
{
"word": "abbreviation",
"transcription": "\u0259brivie\u0283\u0259n"
},
{
"word": "abandoned",
"transcription": "\u0259b\u00e6nd\u0259nd"
},
{
"word": "abash",
"transcription": "\u0259b\u00e6\u0283"
},
{
"word": "abaft",
"transcription": "abaft"
},
{
"word": "abashment",
"transcription": "abashment"
},
{
"word": "abate",
"transcription": "\u0259bet"
},
{
"word": "abbreviate",
"transcription": "\u0259briviet"
},
{
"word": "A1",
"transcription": "a1"
},
{
"word": "abandon",
"transcription": "\u0259b\u00e6nd\u0259n"
},
{
"word": "abase",
"transcription": "abase"
}
]
Note that your requested format is not actually valid JSON. If you do not want the commas and list brackets you can write the file out like this:
with open('file.json') as infile, open('out.json', 'w') as outfile:
d = json.load(infile)
print(*[json.dumps({'word': k, 'transcription': d[k]}, indent=' ') for k in d], file=outfile, sep='\n')
{
"word": "aback",
"transcription": "\u0259b\u00e6k"
}
{
"word": "abandonment",
"transcription": "\u0259b\u00e6nd\u0259nm\u0259nt"
}
{
"word": "abatement",
"transcription": "\u0259betm\u0259nt"
}
{
"word": "abbey",
"transcription": "\u00e6bi"
}
{
"word": "abbreviation",
"transcription": "\u0259brivie\u0283\u0259n"
}
{
"word": "abandoned",
"transcription": "\u0259b\u00e6nd\u0259nd"
}
{
"word": "abash",
"transcription": "\u0259b\u00e6\u0283"
}
{
"word": "abaft",
"transcription": "abaft"
}
{
"word": "abashment",
"transcription": "abashment"
}
{
"word": "abate",
"transcription": "\u0259bet"
}
{
"word": "abbreviate",
"transcription": "\u0259briviet"
}
{
"word": "A1",
"transcription": "a1"
}
{
"word": "abandon",
"transcription": "\u0259b\u00e6nd\u0259n"
}
{
"word": "abase",
"transcription": "abase"
}
Finally, if the order is important you can iterate over the sorted keys, just use:
for k in sorted(d)
where appropriate.