对比json对象

这段代码定义了一个名为`AdchinaJson`的对象,包含两个方法:`Getdifferent`用于比较两个JSON对象并删除相同属性,`Json2Str`将JSON对象转换为字符串。`aaa`函数中,`AdchinaJson.Getdifferent`被用来比较并处理`a`和`b`两个对象,然后打印处理后的结果以及转换为字符串的`a`和`b`。
var AdchinaJson = {};
		function aaa(){
			var a ={
				a:"111",
				b:"222",
				c:[{
					a:"333",
					b:"444",
					d:"555"
				}]
			}
			
			var b={
				a:"111",
				b:"223",
				c:[{
					a:"333",
					b:"444",
					c:"444"
				}]
			}
			AdchinaJson.Getdifferent(a,b);
			console.log(AdchinaJson);
			console.log(AdchinaJson.Json2Str(a));
			console.log(AdchinaJson.Json2Str(b));
		}	
		
		AdchinaJson.Getdifferent = function (json1, json2) {
		    for (var key in json1) {//循环遍历其中一个json对象
		        if (typeof (json1[key]) != "object") {
		            if (json2[key] != null) {
		                if (json1[key] == json2[key]) {
		                    delete json1[key];
		                    delete json2[key];
		                }
		            }
		        }
		        else {
		            if (json1[key].length >= 0) {
		                for (i = 0; i < json1[key].length; i++) {
		                    this.Getdifferent(json1[key][i], json2[key][i]);
		                }
		            }
		            else {
		                this.Getdifferent(json1[key], json2[key]);
		            }
		        }
		    }
		}
		AdchinaJson.Json2Str = function (o) {
		    var arr = [];
		    var fmt = function (s) {
		        if (typeof s == 'object' && s != null) return AdchinaJson.Json2Str(s);
		        return /^(string|number)$/.test(typeof s) ? "'" + s + "'" : s;
		    }
		    for (var i in o) arr.push("'" + i + "':" + fmt(o[i]));
		    return '{' + arr.join(',') + '}';
		}
		      
### JSON 对象 vs 文本 文件 vs CSV 文件 格式特点、性能及使用场景对比分析 #### 1. 数据格式特点 - **JSON对象**: JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,易于人阅读和编写,同时也易于机器解析和生成。它基于键值对的形式来描述数据结构,支持数组、嵌套对象等多种复杂数据形式[^4]。 - **文本文件**: 文本文件是最基本的一种数据存储方式,通常由一系列字符组成,不具有特定的结构化特性。它可以用来保存任何形式的文字信息,但缺乏标准化的字段定义机制[^3]。 - **CSV文件**: CSV(Comma-Separated Values)是以逗号分隔的表格型数据文件格式,适合表达二维表单中的行列关系。每一行代表一条记录,每条记录通过逗号分割成多个字段。 #### 2. 绩效表现 - **JSON对象**: 尽管其灵活性高,但由于是纯文本格式,在处理大规模数据集时存在明显的性能瓶颈。具体表现为读写速度较慢以及较大的文件尺寸,特别是在涉及亿级别以上的海量数据操作时效率较低。 - **文本文件**: 纯粹的文本文件没有固定的模式或标准去衡量它的性能优劣;然而由于缺少结构性设计,当面对复杂的查询需求或者频繁更新的情况时会显得力不从心。 - **CSV文件**: 相对于JSON而言,CSV因其简单的平面结构而拥有更快的速度与更小的空间开销。但是,如果遇到多层嵌套或者是非均匀分布的数据,则可能难以有效表示这些情况下的全部细节[^2]。 #### 3. 应用领域 - **JSON对象**: 广泛应用于Web服务接口之间传递消息体内容,尤其是在前后端分离架构下成为主流选择之一。另外也常见于配置文件等领域当中,因为能够清晰直观地展示层次化的参数设置项。 - **文本文件**: 主要适用于日志记录、说明文档撰写等方面的工作场合之中。这类用途并不追求高度组织化的呈现效果而是注重自由度高的创作环境。 - **CSV文件**: 常被用于统计学软件导入导出过程里边作为中间媒介载体角色出现,比如Excel电子表格应用就经常依赖于此种类型的外部链接源来进行批量数据分析作业。 ```python import csv import json def convert_csv_to_json(csv_file, json_file): with open(csv_file, mode='r', encoding='utf-8') as f: reader = csv.DictReader(f) rows = list(reader) with open(json_file, mode='w', encoding='utf-8') as f: json.dump(rows, f, indent=4) convert_csv_to_json('example.csv', 'output.json') ``` 上述代码展示了如何将一个`.csv`文件转化为`.json`文件的一个实例函数 `convert_csv_to_json()` 的实现方法[^1]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值