记录瞬间

前段时间为了解决一些实际问题,引出了要对json字符串进行比对的需求。

觉得有意义,作以简单记录。

# 比对数据
def compare_data(set_key, src_data, dst_data, noise_data, num):
if isinstance(src_data, dict) and isinstance(dst_data, dict):
"""若为dict格式"""
for key in dst_data:
if key not in src_data:
print("src不存在这个key")
noise_data[key] = "src不存在这个key"
for key in src_data:
if key in dst_data:
if src_data[key] != dst_data[key] and num == 1:
noise_data[key] = "容忍不等"
if src_data[key] != dst_data[key] and num == 2:
noise_data[key] = {}
noise_data[key]["primary"] = src_data[key]
noise_data[key]["candidate"] = dst_data[key]
"""递归"""
compare_data(key, src_data[key], dst_data[key], noise_data, num)
else:
noise_data[key] = ["dst不存在这个key"]
elif isinstance(src_data, list) and isinstance(dst_data, list):
"""若为list格式"""
if len(src_data) != len(dst_data) and len(set_key) != 0:
print("list len: '{}' != '{}'".format(len(src_data), len(dst_data)))
noise_data[set_key]["primary"] = str(src_data)
noise_data[set_key]["candidate"] = str(dst_data)
return
if len(src_data) == len(dst_data) and len(src_data) > 1:
for index in range(len(src_data)):
for src_list, dst_list in zip(sorted(src_data[index]), sorted(dst_data[index])):
"""递归"""
compare_data("", src_list, dst_list, noise_data, num)
else:
for src_list, dst_list in zip(sorted(src_data), sorted(dst_data)):
"""递归"""
compare_data("", src_list, dst_list, noise_data, num)
else:
if str(src_data) != str(dst_data):
print("src_data", src_data, "dst_data", dst_data)
return noise_data

代码实现了出入的src_data、dst_data两个字符串,noise_data作为记录两个字符串的差异进行返回。

set_key是对json串中存在key值对应的list列表时,比对了列表长度不等,我们认为不需要在对列表中的具体元素进行对比。

num区分第一次对比和第二次对比时需要记录的选项。

# 分析获取的数据,并清空存储
def analyse_data():
noise_data1 = {}
mark_result = compare_data("", response["primary"], response["secondary"], noise_data1, 1)
noise_data2 = {}
comp_result = compare_data("", response["primary"], response["candidate"], noise_data2, 2)
td1 = "<tr><td style=\"background-color: #fcf8e3\">"
td2 = "</td><td style=\"width: 45%;padding: 8px;background-color: " \
"#dff0d8;line-height: 1.42857143;vertical-align: left;\"><pre style=\"white-space: pre-wrap!important;" \
"word-wrap: break-word!important;*white-space:normal!important;\">"
diff_td2 = "</td><td style=\"width: 45%;padding: 8px;background-color: " \
"#dff0d8;line-height: 1.42857143;vertical-align: left;\">"
diff_td3 = "</td><td style=\"width: 45%;padding: 8px;background-color: " \
"#dff0d8;line-height: 1.42857143;vertical-align: left;\">"
with open("./result.html", mode="a", encoding="UTF-8") as f:
print(td1 + "Response : ", td2 + json.dumps(response["primary"], indent=4, ensure_ascii=False) + "</pre>" +
td2 + json.dumps(response["candidate"], indent=4, ensure_ascii=False) + "</pre></td></tr>", file=f)
print("mark = ", mark_result)
print("comp = ", comp_result)
if (len(comp_result) - len(mark_result)) > 0:
diff_td = "<tr><td rowspan=\"" + str(len(comp_result) - len(mark_result)) + "\" style=\"background-color: #bf466a\">"
print("diff_td = ", diff_td)
with open("./result.html", mode="a", encoding="UTF-8") as f:
print(diff_td + "Diff Result ", file=f)
for key in comp_result:
if key not in mark_result:
try:
with open("./result.html", mode="a", encoding="UTF-8") as f:
print(diff_td2 + key + "->" + str(noise_data2[key]["primary"]) +
diff_td3 + str(noise_data2[key]["candidate"]) + "</td></tr><tr>", file=f)
# print(key + " = A:" + str(noise_data2[key]["primary"]) + "<->D:" + str(noise_data2[key]["candidate"])
            #     + " Maybe a new bug.", file=f)
print(key, "有可能是bug,要检查了。", str(noise_data2[key]["primary"]), str(noise_data2[key]["candidate"]))
except Exception as e:
with open("./result.html", mode="a", encoding="UTF-8") as f:
print(td1 + "Diff Result : ", td2 + str(noise_data2[key]["primary"]) + "</pre>" +
td2 + str(noise_data2[key]["candidate"]) + "</pre></td></tr>", file=f)
# print(key + " = A:" + str(noise_data2[key]["primary"]) + "<->D:" + str(noise_data2[key]["candidate"])
            #     + " Maybe a new bug.", file=f)
print(e) noise_data1.clear()
noise_data2.clear()
response.clear()

这里的response作为全局的变量进行使用。我们在获取了噪音数据noise_data1和noise_data2时,对噪音数据进行比对。

添加到result.html网页中,作为呈现的文本。

============================================

python实现比对两个json串的方法的更多相关文章

  1. 比较任意两个JSON串是否相等(比较对象是否相等)JAVA版

    废话少说,直接入题. 在面向对象语言中,经常会比较两个对象是否相等,而比较的大多是实体类实例,也就是封装数据的那些类实例,或者是Map.List互相嵌套成的复杂数据结构. 比较对象是否相等,常见的思路 ...

  2. 9-2、大型项目的接口自动化实践记录----递归判断两个json串是否相等

    1.已知json串构成的情况下判断 先构造一下场景,假设已经把各个数据都移除掉不对比的字段 图1 预期.实际结果,复杂接口返回多层嵌套json时,同下 图2 预期.实际结果值为:{child_json ...

  3. Python: 自定义类对象序列化为Json串

    之前已经实现了Python: Json串反序列化为自定义类对象,这次来实现了Json的序列化. 测试代码和结果如下: import Json.JsonTool class Score: math = ...

  4. Python中读取文件中的json串,并将其写入到Excel表格中

    Json:JavaScript Objective Notation,是一种轻量级的数据交换格式.Json最广泛的应用是作为AJAX中web服务器和客户端的通讯的数据格式.现在也常用语http请求中, ...

  5. python 单双引号交替的json串

    单双引号交替的json串 1.常见的json串,类似于这种{"isSucess":true, "name":"yoyo", "st ...

  6. 含有特殊字符的JSON串解析方法

    工具方法:public static <T> T parseJsonString(String json,Class<T> classType){ ObjectMapper m ...

  7. [原创] C# dynamic拼接Json串

    using Newtonsoft.Json; 之前拼接两个json串,是用的这样的代码 , json1.Length - ); json2 = json2.Insert(json2 - , tmp); ...

  8. 怎么解析json串在.net中

    以前知道一种解析json串的方法,觉得有点麻烦.就从别的地方搜到了另一种 string json = vlt.getlist(); JObject jo = JObject.Parse(json); ...

  9. 在.net中怎么解析json串 [Error reading JObject from JsonReader. Current JsonReader item is not an obj]

    编辑时间:2017-05-10,增加一种转化list的方法 一.以前知道一种解析json串的方法,觉得有点麻烦.就从别的地方搜到了另一种 string json = vlt.getlist(); JO ...

随机推荐

  1. ubuntu如何安装或更换内核

    内核是一个系统的灵魂,系统在启动的时候,就是基于相关的内核启动该系统的.我们怎么样更改ubuntu系统的内核并运行它呢? ubuntu18.04LTS 互联网安装内核. 安装内核的步骤非常简单,我们可 ...

  2. [转]SpringMVC+ Mybatis 配置多数据源 + 手动切换数据源

    正确可行的解决方法:使用Spring提供的AbstractRoutingDataSource类来根据请求路由到不同的数据源.具体做法是先设置两个不同的dataSource代表不同的数据源,再建一个总的 ...

  3. 【OCP、OCM、高可用等】小麦苗课堂网络班招生简章(从入门到专家)--课程大纲

    [OCP.OCM.高可用等]小麦苗课堂网络班招生简章(从入门到专家)--课程大纲 小麦苗信息 我的个人信息 网名:小麦苗 QQ:646634621 QQ群:618766405 我的博客:http:// ...

  4. 使用 pt-online-schema-change 实现在线DDL

    问题背景 平时进行修改表的结构,更改字段,新增字段,更改字段名称一般都是通过ALTER TABLE  语法进行修改的.对于小表或者并发访问不是很大的情况是OK.但是如果是在线大表,那就很麻烦.由于表数 ...

  5. Android深入源代码分析理解Aidl总体调用流程(雷惊风)

    2017年開始上班的第一天.老不想工作了,假期感觉还没開始就已经结束了,唉,时间就是这样,新的一年開始了,尽管非常不想干正事,没办法,必须干起来.由于后边的路还非常长,距离六十岁还非常远. 刚上班也没 ...

  6. go异常处理原则

    如果你定义的函数有可能失败,它就应该返回一个错误.当我调用其他package的函数时,如果这个函数实现的很好,我不需要担心它会panic,除非有真正的异常情况发生,即使那样也不应该是我去处理它.而pa ...

  7. fetch get方法的时候报错

    fetch 报错 Failed to execute 'fetch' on 'Window': Request with GET/HEAD method cannot have body. 翻译过来就 ...

  8. ToolBar样式颜色,图标设置

    extends:http://blog.csdn.net/w1054993544/article/details/48339565 <resources> <style name=& ...

  9. 动态HTMl处理

    后续爬虫代码的建议 尽量减少请求次数 1. 能抓列表页就不抓详情页 2. 保存获取的html页面,供差错和重复请求使用 关注网站的所有类型的页面 1. wap页面,触屏版页面 2. H5页面 3. A ...

  10. ArcGIS AddIN异常:无法注册程序集 未能加载文件或程序集"ESRI.ArcGIS.Desktop.Addins"

    异常: 无法注册程序集“D:\CodeXX\bin\Debug\XX.dll”.未能加载文件或程序集“ESRI.ArcGIS.Desktop.AddIns, Version=10.1.0.0, Cul ...