【python】比较两个json并返回差别
来源:互联网 发布:oa数据库设计文档 编辑:程序博客网 时间:2024/05/16 08:06
现在要比较两个json是否相等,若不同则返回差别
比如下面dict数据的对比:
dict1 = {"id": "50356270565167104", "name": "班级优化"}dict2 = {"id": "50356270565167104", "name": "班级优化2"}
对比两个dict是否相等
for src_list, dst_list in zip(sorted(dict1), sorted(dict2)): if str(dict1[src_list]) != str(dict2[dst_list]): print(src_list,dict1[src_list],dst_list,dict2[dst_list])
输出为
name 班级优化 name 班级优化2
如果数据格式为
dict1 = {"id": "503", "name": "班级优化", "info": {"uid":"2017","stuName":["张三","李四"]}}dict2 = {"id": "503", "name": "班级优化2", "info": {"uid":"2017","stuName":["张三","赵五"]}}
此时需要使用递归函数进行处理
首先看一个简单的递归函数
def fact(n): if n==1: return 1 else: return n*fact(n-1)
对比这两个dict:
def cmp(src_data,dst_data): if isinstance(src_data, dict): """若为dict格式""" for key in dst_data: if key not in src_data: print("src不存在这个key") for key in src_data: if key in dst_data: thiskey = key """递归""" cmp(src_data[key], dst_data[key]) else: dic[key] = ["dst不存在这个key"] elif isinstance(src_data, list): """若为list格式""" if len(src_data) != len(dst_data): print("list len: '{}' != '{}'".format(len(src_data), len(dst_data))) for src_list, dst_list in zip(sorted(src_data), sorted(dst_data)): """递归""" cmp(src_list, dst_list) else: if str(src_data) != str(dst_data): print(src_data)
输出为
班级优化李四
阅读全文
1 0
- 【python】比较两个json并返回差别
- 比较两个字符串并返回(第十七周上机任务)
- 第17周项目2--比较两个字符串并返回
- 比较两个表的数据差别
- Linux中比较两个文件的差别
- shell怎么比较两个文件夹的差别
- python 递归比较两个dict或json(相等,包含)
- 返回并解析json
- python mysql 返回json
- python bottle json 返回
- python,比较两个xml
- Excel比较两个工作表(Sheet)的两组列数据,并返回相应数据
- json返回list,并接收。
- svn中比较两个版本之间的差别
- android发送json并解析返回json
- android发送json并解析返回json
- git diff 两个分支的差别,并生成patch
- php 用post方法传json 数据到python程序中并取得返回值
- HDU 4685 Prince and Princess(求所有二分图最大匹配)
- K-server问题
- 使用webpack合并js文件
- 【Linux学习】linux下 各种解压文件使用方法
- 标准库之栈和队列的使用
- 【python】比较两个json并返回差别
- 【机器学习】主成分分析PCA
- C++关键字---friend
- nodejs入门(00)
- Oracle与sql
- 常用坐标系和投影分析-GIS的核心基础
- MYSQL删除表的记录后如何使ID从1开始
- [PAT-甲级]1003.Emergency
- 数据库切换oracle to mysql的坑--Caused by: java.sql.SQLException: Column '' not found.