J'obtiens une chaîne JSON qui contient un élément "\r"
quelque part, par exemple "{"data":"foo \r\n bar"}"
Lorsque j'essaie de l'analyser, il produit ValueError
.
>>> j="""{"data":"foo \r\n bar"}"""
>>> import json
>>> f=json.loads(j)
Traceback (most recent call last):
File "<pyshell#2>", line 1, in <module>
f=json.loads(j)
File "C:\Python27\lib\json\__init__.py", line 326, in loads
return _default_decoder.decode(s)
File "C:\Python27\lib\json\decoder.py", line 366, in decode
obj, end = self.raw_decode(s, idx=_w(s, 0).end())
File "C:\Python27\lib\json\decoder.py", line 382, in raw_decode
obj, end = self.scan_once(s, idx)
ValueError: Invalid control character at: line 1 column 13 (char 13)
>>> j[13]
'\r'
"\r"
est un caractère parfaitement légal dans une chaîne Python.
Comment puis-je analyser cette chaîne JSON de telle sorte que
>>> dct = somehow_parse_json(j)
>>> dct['data']
'foo \r\n bar'
Je pourrais facilement trouver et extraire les caractères de retour chariot, mais je préférerais qu'ils puissent être sauvegardés.