C# DataSet转JSON

  经常会遇到系统数据交互采用JSON数据格式进行交互的,避免不必要的重复工作,记录下自己的处理方式。

获取数据集之后,通过函数对数据集信息进行整理通过.Net Framework3.5提出的JavaScriptSerializer类进行DataSet数据的序列化,

需要添加System.Web.Extensions引用:

 private static string DataToJson(DataSet metaData,string msg){            DataTable resultInfo = new DataTable("success");resultInfo.Columns.Add("RETURN_CODE", Type.GetType("System.String"));resultInfo.Columns.Add("ERROR_MSG", Type.GetType("System.String"));DataRow newRow = resultInfo.NewRow();if (metaData == null || metaData.Tables.Count <= 0 || metaData.Tables[0].Rows.Count <= 0){newRow["RETURN_CODE"] = "-1";if (string.IsNullOrEmpty(msg)){newRow["ERROR_MSG"] = "查询结果为空";}else{newRow["ERROR_MSG"] = msg;}resultInfo.Rows.Add(newRow);metaData.Tables.Add(resultInfo);}else{newRow["RETURN_CODE"] = "0";newRow["ERROR_MSG"] = "";resultInfo.Rows.Add(newRow);metaData.Tables.Add(resultInfo);}StringBuilder sb = new StringBuilder();sb.Append("{");JavaScriptSerializer serializer = new JavaScriptSerializer();foreach (DataTable dt in metaData.Tables){sb.Append(string.Format("\"{0}\":",dt.TableName));ArrayList arrayList=new ArrayList();foreach (DataRow dataRow in dt.Rows){Dictionary<string, object> dictionary = new Dictionary<string, object>();foreach (DataColumn dataColumn in dt.Columns){dictionary.Add(dataColumn.ColumnName,dataRow[dataColumn.ColumnName]);}arrayList.Add(dictionary);}sb.Append(serializer.Serialize(arrayList));sb.Append(",");}return sb.Remove(sb.Length - 1, 1).Append("}").ToString();}

   此时我们获取了一个JSON格式的字符串,在接收方同样可以通过JavaScriptSerializer将字符串转换为自己需要的数据格式如ArrayList:

        private ArrayList JsonToList(string json){JavaScriptSerializer serializer = new JavaScriptSerializer();Dictionary<string,object> dictionary= serializer.Deserialize<Dictionary<string,object>>(json);return (ArrayList)dictionary["data"];}

      也可以将JSON转换为对象:

 

internal bool ValidateWebJsonValues(ref UserInfo userInfo, string userName, string passWord){try{string json = "{"data":{"accounts":null,"delFlag":"0","email":null,"emailState":null,"instOrgId":null,"institue":false,"member":false,"mobile":null,"org":false,"realName":"包文强","state":"0","teacher":true,"userId":121438653944262,"userType":"2"},"success":true}";JavaScriptSerializer jsSerializer = new JavaScriptSerializer();Dictionary<string, object> dic = jsSerializer.Deserialize<Dictionary<string, object>>(json);bool dataResult = (bool)dic["success"];if (dataResult){Dictionary<string, object> dataDic = (Dictionary<string, object>)dic["data"];Type type = typeof(UserInfo);PropertyInfo[] propInfo = type.GetProperties();foreach (PropertyInfo prop in propInfo){if (dataDic[prop.Name] != null){prop.SetValue(userInfo, dataDic[prop.Name], null);}else{prop.SetValue(userInfo, "", null);}}}return dataResult;}catch (Exception ex){return false;}}

以上代码是根据个人过往处理这方面问题的代码进行简单调整,也涉及到一些判断逻辑。作为参考,可以修改调整后使用。

转载于:https://www.cnblogs.com/ultimateWorld/p/6062303.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/489610.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

zset中的score_Redis 在项目中合理使用经验总结

背景Redis 是一个开源的内存数据结构存储系统。可以作为数据库、缓存和消息中间件使用。支持多种类型的数据结构。Redis 内置了 复制&#xff08;replication&#xff09;&#xff0c;LUA脚本&#xff08;Lua scripting&#xff09;&#xff0c; LRU驱动事件&#xff08;LRU ev…

八种颠覆未来作战的前沿技术

来源&#xff1a;军事高科技在线目录一、颠覆未来作战的前沿技术系列——脑科学二、颠覆未来作战的前沿技术系列——人体增强三、颠覆未来作战的前沿技术系列——石墨烯四、颠覆未来作战的前沿技术系列——超材料五、颠覆未来作战的前沿技术系列——太赫兹技术六、颠覆未来作战…

Linux下查看/管理当前登录用户及用户操作历史记录

转载自&#xff1a; http://www.cnblogs.com/gaojun/archive/2013/10/24/3385885.html 一、查看及管理当前登录用户 1、使用w命令查看登录用户正在使用的进程信息&#xff0c;w命令用于显示已经登录系统的用户的名称&#xff0c;以及他们正在做的事。该命令所使用的信息来源于/…

python狗图像识别_TensorFlow卷积神经网络之使用训练好的模型识别猫狗图片

本文是Python通过TensorFlow卷积神经网络实现猫狗识别的姊妹篇&#xff0c;是加载上一篇训练好的模型&#xff0c;进行猫狗识别本文逻辑&#xff1a;我从网上下载了十几张猫和狗的图片&#xff0c;用于检验我们训练好的模型。处理我们下载的图片加载模型将图片输入模型进行检验…

Java对象垃圾回收调用,JVM垃圾回收之哪些对象可以被回收

1.背景Java语言相比于C和C&#xff0c;一个最大的特点就是不需要程序员自己手动去申请和释放内存&#xff0c;这一切交由JVM来完成。在Java中&#xff0c;运行时的数据区域分为程序计数器、Java虚拟机栈、本地方法栈、方法区和堆。其中&#xff0c;程序计数器、虚拟机栈和本地方…

hp

命令组成hpacucli [parametervalue] 查看&#xff1a; 查看所有控制器状态 hpacucli ctrl all show 查看slot 0阵列信息详细状态 &#xff08;可以查看物理磁盘和逻辑磁盘的对应关系&#xff09;1&#xff09;hpacucli ctrl slot0 show config detail2&#xff09;hpacucli ct…

报告|机器人行业深度报告:机器人产业价值与回报相关度分析

来源&#xff1a;机器人大讲堂2009&#xff5e;2018年中国工业机器人保有量在全球保有量的占比稳步提升。据IFR数据&#xff0c;截止2018年底&#xff0c;中国工业机器人保有量达到64.94万台&#xff0c;全球占比为26.97%。2013&#xff5e;2018年间中国新增工业机器人中国产品…

python 笔记本_Python笔记本

Python 的主提示符( >>> )和次提示符( ... )。主提示符是解释器告诉你它在等你输入下一个语句,次提示符告诉你解释器正在等待你输入当前语句的其它部分。下划线(_)在解释器中有特别的含义,表示最后一个表达式的值。所以上面的代码执行之后,下划线变量会包含字符串In […

百度面试 php后端,2019.7最惨的三次面试经历-----百度PHP实习生面经

一、百度--文娱架构部一面 半小时 前台小姐姐很漂亮都是根据简历上写的来问的&#xff0c;说几个知道的排序算法&#xff0c;讲讲堆排序&#xff0c;堆是什么结构&#xff0c;我说堆类似于完全二叉树&#xff0c;讲讲完全二叉树和满二叉树的区别&#xff0c;手撕快速排序&#…

netty客户端源码

随笔记录。 //创建一个ChannelFactory&#xff08;客户端代码&#xff09; ChannelFactory factory new NioClientSocketChannelFactory( Executors.newCachedThreadPool(), Executors.newCachedThreadPool()); // NioClientSocketChannelFactory构造方法 public NioClientSoc…

汉字的ascii码值范围_ASCII代码

同学们&#xff0c;我们都知道计算机只能接受二进制信息&#xff0c;很显然直接给出英文的ABCD计算机并不认识&#xff0c;那为何敲击键盘屏幕就可以显示出对应的字符呢&#xff1f;为了解决这个问题&#xff0c;计算机采用一套编码&#xff0c;每个编码都是唯一的&#xff0c;…

从ICLR提交论文看机器学习的趋势和风口

大数据文摘出品来源&#xff1a;deepsense2013年才举办第一届的ICLR&#xff08;The International Conference on Learning Representations&#xff09;发展迅猛&#xff0c;如今已成为是最重要的国际机器学习会议之一&#xff0c;甚至可以和ICML&#xff0c;NeurIPS和CVPR这…

php 登录安全认证,介绍几种常用的web安全认证方式

本文为大家介绍了五种常用的web安全认证方式&#xff0c;具有一定的参考价值&#xff0c;希望能对大家有所帮助。1、Http Basic Auth这是一种最古老的安全认证方式&#xff0c;这种方式就是简单的访问API的时候&#xff0c;带上访问的username和password&#xff0c;由于信息会…

日期选择控件-laydate

laydate控件非常简单易用&#xff0c;只需要调用一个个函数就可以轻松实现日期时间选择。 <% page language"java" import"java.util.*" pageEncoding"UTF-8"%><%String path request.getContextPath();String basePath request.getS…

python decorator. decorator_Python中decorator使用实例

在我以前介绍 Python 2.4 特性的Blog中已经介绍过了decorator了&#xff0c;不过&#xff0c;那时是照猫画虎&#xff0c;现在再仔细描述一下它的使用。关于decorator的详细介绍在 Python 2.4中的Whats new中已经有介绍&#xff0c;大家可以看一下。如何调用decorator基本上调用…

php文件上传到虚拟主机,php源码上传到虚拟主机(php源码上传到服务器)

php网站的源码在上传到虚拟主机之前&#xff0c;需要做什么修改本人小白&#xff0c;只知道需。这个啊&#xff0c;倒是简单&#xff0c;你下载个ftp软件&#xff0c;登陆上传即可&#xff0c;不过要注意传对目录&#xff0c;一般的虚拟主机都有好几目录的&#xff0c;要传合适…

这个“大脑”收获一份大奖!

来源&#xff1a;新华社第17届亚洲-太平洋通讯社组织&#xff08;亚通组织&#xff09;全体大会8日在韩国首尔闭幕。大会颁发了亚通组织卓越通讯社品质奖&#xff0c;中国新华通讯社与越南通讯社分别获奖。这是亚通组织主席、阿塞拜疆国家新闻社社长阿斯兰阿斯兰诺夫&#xff0…

arm-linux-gnueabi和arm-linux-gnueabihf 的区别

转载整理自&#xff1a;http://www.cnblogs.com/xiaotlili/p/3306100.html 一、 什么是ABI和EABI1 、ABI ABI(二进制应用程序接口-Application Binary Interface (ABI) for the ARM Architecture)在计算机中&#xff0c;应用二进制接口描述了应用程序&#xff08;或者其他类型&…

检查用户名是否存在的servlet代码怎么写_Servlet详解!!!

1 掌握 请求转发2 掌握 请求重定向3 掌握cookie1. 请求转发介绍(1) 为什么需要请求转发?以此请求的处理需要多个Servlet的联动操作,第一个Servlet需要用到其他Servlet已经声明的逻辑处理代码(2) 请求转发的本质是什么&#xff1f;其实就是在一个Servlet中调用其他的Servlet2. …

学习人工智能必须攻克三道门槛:数学基础、英语水平与编程技术

来源&#xff1a;搜狐广义的说&#xff0c;人工智能包含诸多不同方法&#xff0c;其主旨是让程序像一个智能体一样解决问题。机器学习是实现人工智能的一种方法&#xff0c;它不完全依靠预先设计&#xff0c;而是从数据中进行总结&#xff0c;达到模拟记忆、推理的作用。包括诸…