python代码修复字符串json数据格式问题,并将其按照字典形式读取

修复代码

python 复制代码
def aggressive_json_load(s):
    """
    终极修复:处理嵌套、残缺补齐、以及末尾多余的垃圾字符
    """
    if not isinstance(s, str): return None
    
    s = s.strip()
    if not (s.startswith('{') or s.startswith('[')): return None

    # 1. 尝试直接加载
    try:
        return json.loads(s)
    except json.JSONDecodeError:
        pass

    # 2. 括号平衡补齐逻辑
    def balance_json(text):
        stack = []
        for char in text:
            if char == '{': stack.append('}')
            elif char == '[': stack.append(']')
            elif char == '}':
                if stack and stack[-1] == '}': stack.pop()
            elif char == ']':
                if stack and stack[-1] == ']': stack.pop()
        return text + "".join(reversed(stack))

    # 3. 尝试修复多余的尾部字符(如案例中的 \n})
    # 逻辑:如果直接补齐不行,尝试截断到最后一个可能的闭合符再补齐
    trial_s = s
    while len(trial_s) > 0:
        fixed = balance_json(trial_s)
        try:
            return json.loads(fixed)
        except json.JSONDecodeError:
            # 删掉最后一个字符,继续尝试(处理尾部多余垃圾)
            trial_s = trial_s[:-1].rstrip()
            if not trial_s or trial_s[-1] not in ('"', '}', ']', 'e', 't', 'f', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9'):
                # 优化性能:只有在可能结束的位置才尝试解析
                continue
                
    return None

def universal_cleaner(data):
    """
    递归扫描所有数据结构,自动解开所有嵌套 JSON 字符串
    """
    if isinstance(data, dict):
        return {k: universal_cleaner(v) for k, v in data.items()}
    elif isinstance(data, list):
        return [universal_cleaner(item) for item in data]
    elif isinstance(data, str):
        decoded = aggressive_json_load(data)
        if decoded is not None:
            # 递归处理"剥壳"后的内容
            return universal_cleaner(decoded)
        return data
    return data

测试

python 复制代码
raw_input = {
    "response": [
        # 情况 A: 带垃圾字符的字符串 JSON
        "{\"name\": \"cyclingSafety.checkHelmetSafety\", \"arguments\": {\"helmet_model\": \"SpeedSter Pro\"}}\n}", 
        # 情况 B: 正常的字典
        {
            "name": "cyclingSafety.checkHelmetSafety",
            "arguments": {"helmet_model": "MountainMaster X"}
        }
    ]
}

cleaned_data = universal_cleaner(raw_input)

# 打印验证结果
import pprint
pprint.pprint(cleaned_data)
相关推荐
小白学大数据2 小时前
链家二手房数据爬取、聚类分析与可视化展示实践
开发语言·爬虫·python
春日见2 小时前
三分钟安装window Docker,并与Ubuntu(WSL)建立连接
linux·人工智能·windows·驱动开发·机器学习·docker·容器
白衣衬衫 两袖清风2 小时前
Docker日志清理,防止磁盘被json.log撑爆
docker·容器·json
梦想的旅途22 小时前
企业微信API自动化高效开发的实战指南
开发语言·python
幸福的达哥2 小时前
PyQt5多线程UI更新方法
python·qt·ui
玄同7652 小时前
SQLAlchemy 会话管理终极指南:close、commit、refresh、rollback 的正确打开方式
数据库·人工智能·python·sql·postgresql·自然语言处理·知识图谱
喵手2 小时前
Python爬虫零基础入门【第九章:实战项目教学·第11节】Playwright 入门实战:渲染后 HTML + 截图定位问题!
爬虫·python·爬虫实战·playwright·python爬虫工程化实战·零基础python爬虫教学·渲染html
一晌小贪欢2 小时前
Python ORM 深度解析:告别繁琐 SQL,让数据操作如丝般顺滑
开发语言·数据库·python·sql·python基础·python小白
华研前沿标杆游学2 小时前
2026智启新程 | 走进华为及商汤科技参观研学高级研修班
python