[原创] C# dynamic拼接Json串
using Newtonsoft.Json;
之前拼接两个json串,是用的这样的代码
var tmp = "," + json1.Substring(, json1.Length - );
json2 = json2.Insert(json2 - , tmp);
虽然效率挺高的,但是代码很丑啊
字符串操作的缺陷:
1)不优雅
2)不通用
3)没有办法替换原有的值
后来想起可以用dynamic类型来实现
如
string json111, json112;
json111 = "{'a':1,'b':2,'d':{}}";
json112 = "{'c':[1,2,3]}";
Console.WriteLine(json111);
Console.WriteLine(json112);
dynamic d111 = JsonConvert.DeserializeObject<object>(json111);
dynamic d112 = JsonConvert.DeserializeObject<object>(json112);
d111["c"] = d112["c"]; string json110 = JsonConvert.SerializeObject(d111 as object);
Console.WriteLine(json110);
原来是用的 d111.c=d112.c,但是这又相当 不通用,而用 d111["c"]=d112["c"];用变量来代替属性显示更通用些
甚至可以拼接二级属性
d111["d"]["d2"] = d112["c"];
这代码显示更优雅些,但是效率肯定不如直接字符串操作了!!
通用代码如下:
/// <summary>
/// 拼接两个Json串,将targetJson插入到sourceJson中
/// 暂时仅支持一级属性
/// </summary>
/// <param name="sourceJson">源Json串</param>
/// <param name="targetJson">插入Json串</param>
/// <param name="propNames">要插入Json的属性列表</param>
/// <returns>拼接好的Json串</returns>
static string ConcatJson(string sourceJson, string targetJson, string[] propNames)
{
dynamic source = JsonConvert.DeserializeObject<object>(sourceJson);
dynamic target = JsonConvert.DeserializeObject<object>(targetJson);
foreach (var prop in propNames)
{
source[prop] = target[prop];
} return JsonConvert.SerializeObject(source as object);
}
调用如下:
string json111, json112;
json111 = "{'a':1,'b':2,'d':{}}";
json112 = "{'c':[1,2,3]}";
Console.WriteLine(json111);
Console.WriteLine(json112);
string json113 = ConcatJson(json111, json112, new string[] {"c"});
Console.WriteLine(json113);
缺陷:
1)需要传插入json的属性列表..还是与调用方有耦合(可以确定,用索引是不行的)
2)效率不高,在不讲究效率的场景用还可以
3)不支持多层插入.
如果哪位大神有更好 的办法,请告知我,谢谢!!!
[原创] C# dynamic拼接Json串的更多相关文章
- java拼接JSON串
String str = "{\"route\":\"onGift\",\"time\":\"\",\&quo ...
- @RequestBody与serialize()、serializeArray()、拼接Json 妙用总结
@requestBody注解常用来处理content-type不是默认的application/x-www-form-urlcoded编码的内容, 比如说:application/json或者是app ...
- json 串转成 java 对象再拼接成前台 html 元素
获取商品参数 json 串,转成 java 对象,再拼接成前台 html 的Service方法 @Override public String getItemParam(Long itemId) { ...
- 如何用js定义数组,用js来拼接json字段
定义js数组的方式有: var arr = (); var arr = []; var arr = new Array(); 如何拼接成一个json字段. <!DOCTYPE HTML PUBL ...
- mysql - json串新增字段
1.建表 -- 建表 drop table if exists ta_product2; CREATE TABLE ta_product2( id int primary key auto_incre ...
- HiJson工具 && 火狐浏览器中的jsonHandle插件(以及乱码问题的解决)-->来转换json串的格式
原文:http://blog.csdn.net/cjm2484836553/article/details/72453907 版权声明:本文为博主原创文章,未经博主允许不得转载. 目录(?)[-] ...
- Json串排序
最近遇到个很烦人的问题.我现在做的业务有一部分是把之前app服务端的.net接口转译java接口.但是有些之前的接口,一个接口干上十几件事情,返回的json串长达五六几百行.着实看的就让人头大.但是如 ...
- Json串与实体的相互转换 (不依赖于jar包 只需Eclipse环境即可)
Json串与实体的相互转换 (不依赖于jar包 只需Eclipse环境即可) 最近学习了javaWeb开发,用的是ssh框架里面自己整合了hibernate 和Struts2 和spring框架,其中 ...
- Java开发笔记(一百零八)JSON串的定义和解析
前面提到URL尾巴支持添加请求参数,具体格式形如“参数A名称=A参数值&参数B名称=B参数值”,可是这种格式只能传递简单的键值对信息,不能传递结构化数据,也无法传递数组形式的参数,因而它不适用 ...
随机推荐
- ADT - Eclipse 常用快捷键
ADT - Eclipse 常用快捷键 Alt + / : 自动补全 F3 : 打开类的源码 Ctrl + D : 删除选中行 Ctrl + 1 : 自动弹出修改建议 Ctrl + Shift + J ...
- 使用WebRTC搭建前端视频聊天室——入门篇
http://segmentfault.com/a/1190000000436544 什么是WebRTC? 众所周知,浏览器本身不支持相互之间直接建立信道进行通信,都是通过服务器进行中转.比如现在有两 ...
- FlashBuilder4安装SVN插件步骤
1. 选择菜单 帮助–> 安装新软件 2. 在使用里键入地址: http://subclipse.tigris.org/update_1.6.x并点击添加 在Subclipse栏里选择带有Re ...
- IOS开发基础知识--碎片49
1:iOS项目配置文件info.plist文件解析 Localization native development region本地化 Executable file可执行文件路径 Bundle id ...
- java 接口的作用和好处
1.java 接口的作用 http://blog.csdn.net/hack_bug/article/details/7634737 2.一位Java大牛的回答 很多JAVA初级程序员对于接口存在的意 ...
- 如何写出让java虚拟机发生内存溢出异常OutOfMemoryError的代码
程序小白在写代码的过程中,经常会不经意间写出发生内存溢出异常的代码.很多时候这类异常如何产生的都傻傻弄不清楚,如果能故意写出让jvm发生内存溢出的代码,有时候看来也并非一件容易的事.最近通过学习< ...
- 如何利用mount命令将另外一个linux服务器上的目录挂在到本机?
你先要在192.168.1.100上开启NFS服务并编辑/etc/exports文件: chkconfig --level 35 nfs on service nfs start vi /etc/ex ...
- jsmooth compilation failed error null
JSmooth 0.9.9-7 在将 jar 文件打包成 exe 文件时报错:jsmooth compilation failed error null 原因,没有指定 logo 图片文件. http ...
- java中的浮点数
浮点数值不适用于禁止出现舍入误差的金融计算中.例如,命令System.out.println(2.0-1.1)将打印出0.8999999999999999999999999,而不是人们想象的0.9.其 ...
- MySQL的查询计划中ken_len的值计算
本文首先介绍了MySQL的查询计划中ken_len的含义:然后介绍了key_len的计算方法:最后通过一个伪造的例子,来说明如何通过key_len来查看联合索引有多少列被使用. key_len的含义 ...