json.loads()不支持尾随逗号,须改用宽松解析器;推荐json5.loads(),它原生支持尾随逗号、单引号、注释等,兼容性好且安全。

json.loads() 本身**不支持尾随逗号**(trailing comma),这是 Python 标准库 json 模块的严格实现,完全遵循 RFC 8259 —— 而该标准明确**禁止**对象或数组末尾出现逗号。
如果你需要解析含尾随逗号的字符串(常见于手写配置、前端 JSON-like 输入、或某些编辑器自动补全场景),必须换用**非严格/宽松解析器**。以下是几种实用方案:
用 ast.literal_eval()(仅限简单结构)
适用于不含双引号字符串、无 null/true/false、且语法接近 Python 字面量的输入(例如用单引号、True/False/None):
import asts = "{'name': 'Alice', 'age': 30,}" # 单引号 + 尾随逗号 data = ast.literal_eval(s) # ✅ 成功返回 {'name': 'Alice', 'age': 30}
⚠️ 注意:它不接受双引号字符串、null、true、false,也不支持 Unicode 转义等 JSON 特性,**不是 JSON 替代品,仅作轻量降级使用**。
用 json5 库(推荐:最接近 JSON 的宽松解析)
json5 是专为人类可读设计的 JSON 超集,原生支持:
- 尾随逗号(对象和数组)
- 单引号字符串
- 注释(// 和 /* */)
- undefined、NaN、Infinity(可选转换)
- 十六进制数字、无引号键名(如
{foo: 42})
安装与使用:
pip install json5
import json5s = '''{ "name": "Bob", "hobbies": ["reading", "coding",], // 这是注释 }'''
data = json5.loads(s) # ✅ 完美解析
用 demjson3(功能全面但需注意安全)
demjson3 支持极宽松语法(包括尾随逗号、注释、单引号、重复键处理等),并提供校验级别控制:
pip install demjson3
import demjson3s = '{"x": 1, "y": 2,}' data = demjson3.decode(s, strict=False) # strict=False 启用宽容模式
⚠️ 注意:demjson3 解析能力过强,可能掩盖格式错误;不建议用于不可信输入(潜在执行风险,尽管比 eval 安全)。
预处理字符串(手动移除尾随逗号)
若只处理简单、规则的 JSON 片段(如已知是对象或数组结尾),可用正则临时清理(慎用于嵌套复杂场景):
import re import jsondef loads_with_trailing_comma(s):
移除对象末尾的 { ..., } 中的逗号,和数组末尾的 [ ..., ] 中的逗号
s = re.sub(r',\s*([}\]])', r'\1', s) return json.loads(s)s = '{"a": 1, "b": [2, 3,],}' data = loads_with_trailing_comma(s) # ✅
⚠️ 此法易出错(如字符串内逗号、多层嵌套、换行缩进变化),**仅作临时应急,不推荐生产环境使用**。
总结:要真正可靠地容忍尾随逗号,请放弃 json.loads(),改用 json5.loads() —— 它专为此类需求设计,兼容性好、安全性高、API 与标准 json 几乎一致。










