我注意到单引号导致simplejson的loads功能失败:
simplejson
loads
>>> import simplejson as json >>> json.loads("\"foo\"") 'foo' >>> json.loads("\'foo\'") Traceback (most recent call last): ... ValueError: No JSON object could be decoded
我正在解析以下内容:foo = ["a", "b", "c"]从文本文件转换为Python中的列表,并且也想接受foo = ['a', 'b', 'c']。simplejson便于foo自动将其放入列表。
foo = ["a", "b", "c"]
foo = ['a', 'b', 'c']
foo
我如何才能loads接受单引号,或在不破坏输入的情况下自动将双引号替换为单引号?谢谢。
使用适合该工作的工具,您不是在解析JSON,而是在解析Python,因此请ast.literal_eval()改用:
ast.literal_eval()
>>> import ast >>> ast.literal_eval('["a", "b", "c"]') ['a', 'b', 'c'] >>> ast.literal_eval("['a', 'b', 'c']") ['a', 'b', 'c'] >>> ast.literal_eval('["mixed", \'quoting\', """styles"""]') ['mixed', 'quoting', 'styles']
JSON文件总是使用字符串双引号,使用UTF-16 \uhhhh进制转义语法,具有{...}与键始终字符串键值对的对象和序列总是[...]名单和使用null,true和false值; 请注意小写的布尔值。数字以整数和浮点数形式出现。
\uhhhh
{...}
[...]
null
true
false
在Python中,字符串表示形式可以使用单引号和双引号,Unicode可以转义使用形式\uhhhh和\Uhhhhhhhh形式(没有UTF-16代理对),具有{...}显示语法的字典可以具有许多不同类型的键,而不仅仅是字符串,序列可以是列表([...]),但可以也可以使用元组((...)),否则您仍然可以使用其他容器类型。Python具有None,True和False(Titlecase!),数字以整数,浮点数和复杂形式出现。
\Uhhhhhhhh
(...)
None
True
False
当解码碰巧成功但数据被错误地解释时(例如使用逃脱的非BMP代码点(如Emoji)),将彼此混淆会导致解析错误或细微问题。确保使用正确的方法对其进行解码!在大多数情况下,当您确实拥有Python语法数据时,某人实际上使用了错误的编码方法,并且仅偶然生成了Python表示形式。查看在这种情况下源是否需要修复;通常,输出是通过使用应该代替str(object)where的方式产生的json.dumps(obj)。
str(object)
json.dumps(obj)