/// <summary>   

/// List转成json    

/// </summary>   

/// <typeparam name="T"></typeparam>   

/// <param name="jsonName"></param>   

/// <param name="list"></param>   

/// <returns></returns>   

public static string ListToJson<T>(IList<T> list, string jsonName)   

{   

 StringBuilder Json = new StringBuilder();   

 if (string.IsNullOrEmpty(jsonName))   

  jsonName = list[0].GetType().Name;   

 Json.Append("{\"" + jsonName + "\":[");   

 if (list.Count > 0)   

 {   

  for (int i = 0; i < list.Count; i++)   

  {   

   T obj = Activator.CreateInstance<T>();   

   PropertyInfo[] pi = obj.GetType().GetProperties();   

   Json.Append("{");   

   for (int j = 0; j < pi.Length; j++)   

   {   

    Type type = pi[j].GetValue(list[i], null).GetType();   

    Json.Append("\"" + pi[j].Name.ToString() + "\":" + StringFormat(pi[j].GetValue(list[i], null).ToString(), type));   

  

    if (j < pi.Length - 1)   

    {   

     Json.Append(",");   

    }   

   }   

   Json.Append("}");   

   if (i < list.Count - 1)   

   {   

    Json.Append(",");   

   }   

  }   

 }   

 Json.Append("]}");   

 return Json.ToString();   

}   

  

/// <summary>   

/// List转成json    

/// </summary>   

/// <typeparam name="T"></typeparam>   

/// <param name="list"></param>   

/// <returns></returns>   

public static string ListToJson<T>(IList<T> list)   

{   

 object obj = list[0];   

 return ListToJson<T>(list, obj.GetType().Name);   

}   

  

/// <summary>    

/// 对象转换为Json字符串    

/// </summary>    

/// <param name="jsonObject">对象</param>    

/// <returns>Json字符串</returns>    

public static string ToJson(object jsonObject)   

{   

 string jsonString = "{";   

 PropertyInfo[] propertyInfo = jsonObject.GetType().GetProperties();   

 for (int i = 0; i < propertyInfo.Length; i++)   

 {   

  object objectValue = propertyInfo[i].GetGetMethod().Invoke(jsonObject, null);   

  string value = string.Empty;   

  if (objectValue is DateTime || objectValue is Guid || objectValue is TimeSpan)   

  {   

   value = "'" + objectValue.ToString() + "'";   

  }   

  else if (objectValue is string)   

  {   

   value = "'" + ToJson(objectValue.ToString()) + "'";   

  }   

  else if (objectValue is IEnumerable)   

  {   

   value = ToJson((IEnumerable)objectValue);   

  }   

  else  

  {   

   value = ToJson(objectValue.ToString());   

  }   

  jsonString += "\"" + ToJson(propertyInfo[i].Name) + "\":" + value + ",";   

 }   

 jsonString.Remove(jsonString.Length - 1, jsonString.Length);   

 return jsonString + "}";   

}   

  

/// <summary>    

/// 对象集合转换Json    

/// </summary>    

/// <param name="array">集合对象</param>    

/// <returns>Json字符串</returns>    

public static string ToJson(IEnumerable array)   

{   

 string jsonString = "[";   

 foreach (object item in array)   

 {   

  jsonString += ToJson(item) + ",";   

 }   

 jsonString.Remove(jsonString.Length - 1, jsonString.Length);   

 return jsonString + "]";   

}   

  

/// <summary>    

/// 普通集合转换Json    

/// </summary>    

/// <param name="array">集合对象</param>    

/// <returns>Json字符串</returns>    

public static string ToArrayString(IEnumerable array)   

{   

 string jsonString = "[";   

 foreach (object item in array)   

 {   

  jsonString = ToJson(item.ToString()) + ",";   

 }   

 jsonString.Remove(jsonString.Length - 1, jsonString.Length);   

 return jsonString + "]";   

}   

  

/// <summary>    

/// Datatable转换为Json    

/// </summary>    

/// <param name="table">Datatable对象</param>    

/// <returns>Json字符串</returns>    

public static string ToJson(DataTable dt)   

{   

 StringBuilder jsonString = new StringBuilder();   

 jsonString.Append("[");   

 DataRowCollection drc = dt.Rows;   

 for (int i = 0; i < drc.Count; i++)   

 {   

  jsonString.Append("{");   

  for (int j = 0; j < dt.Columns.Count; j++)   

  {   

   string strKey = dt.Columns[j].ColumnName;   

   string strValue = drc[i][j].ToString();   

   Type type = dt.Columns[j].DataType;   

   jsonString.Append("\"" + strKey + "\":");   

   strValue = StringFormat(strValue, type);   

   if (j < dt.Columns.Count - 1)   

   {   

    jsonString.Append(strValue + ",");   

   }   

   else  

   {   

    jsonString.Append(strValue);   

   }   

  }   

  jsonString.Append("},");   

 }   

 jsonString.Remove(jsonString.Length - 1, 1);   

 jsonString.Append("]");   

 return jsonString.ToString();   

}   

  

/// <summary>   

/// DataTable转成Json    

/// </summary>   

/// <param name="jsonName"></param>   

/// <param name="dt"></param>   

/// <returns></returns>   

public static string ToJson(DataTable dt, string jsonName)   

{   

 StringBuilder Json = new StringBuilder();   

 if (string.IsNullOrEmpty(jsonName))   

  jsonName = dt.TableName;   

 Json.Append("{\"" + jsonName + "\":[");   

 if (dt.Rows.Count > 0)   

 {   

  for (int i = 0; i < dt.Rows.Count; i++)   

  {   

   Json.Append("{");   

   for (int j = 0; j < dt.Columns.Count; j++)   

   {   

    Type type = dt.Rows[i][j].GetType();   

    Json.Append("\"" + dt.Columns[j].ColumnName.ToString() + "\":" + StringFormat(dt.Rows[i][j].ToString(), type));   

    if (j < dt.Columns.Count - 1)   

    {   

     Json.Append(",");   

    }   

   }   

   Json.Append("}");   

   if (i < dt.Rows.Count - 1)   

   {   

    Json.Append(",");   

   }   

  }   

 }   

 Json.Append("]}");   

 return Json.ToString();   

}   

  

/// <summary>    

/// DataReader转换为Json    

/// </summary>    

/// <param name="dataReader">DataReader对象</param>    

/// <returns>Json字符串</returns>    

public static string ToJson(DbDataReader dataReader)   

{   

 StringBuilder jsonString = new StringBuilder();   

 jsonString.Append("[");   

 while (dataReader.Read())   

 {   

  jsonString.Append("{");   

  for (int i = 0; i < dataReader.FieldCount; i++)   

  {   

   Type type = dataReader.GetFieldType(i);   

   string strKey = dataReader.GetName(i);   

   string strValue = dataReader[i].ToString();   

   jsonString.Append("\"" + strKey + "\":");   

   strValue = StringFormat(strValue, type);   

   if (i < dataReader.FieldCount - 1)   

   {   

    jsonString.Append(strValue + ",");   

   }   

   else  

   {   

    jsonString.Append(strValue);   

   }   

  }   

  jsonString.Append("},");   

 }   

 dataReader.Close();   

 jsonString.Remove(jsonString.Length - 1, 1);   

 jsonString.Append("]");   

 return jsonString.ToString();   

}   

  

/// <summary>    

/// DataSet转换为Json    

/// </summary>    

/// <param name="dataSet">DataSet对象</param>    

/// <returns>Json字符串</returns>    

public static string ToJson(DataSet dataSet)   

{   

 string jsonString = "{";   

 foreach (DataTable table in dataSet.Tables)   

 {   

  jsonString += "\"" + table.TableName + "\":" + ToJson(table) + ",";   

 }   

 jsonString = jsonString.TrimEnd(',');   

 return jsonString + "}";   

}   

  

/// <summary>   

/// 过滤特殊字符   

/// </summary>   

/// <param name="s"></param>   

/// <returns></returns>   

private static string String2Json(String s)   

{   

 StringBuilder sb = new StringBuilder();   

 for (int i = 0; i < s.Length; i++)   

 {   

  char c = s.ToCharArray()[i];   

  switch (c)   

  {   

   case '\"':   

    sb.Append("\\\""); break;   

   case '\\':   

    sb.Append("\\\\"); break;   

   case '/':   

    sb.Append("\\/"); break;   

   case '\b':   

    sb.Append("\\b"); break;   

   case '\f':   

    sb.Append("\\f"); break;   

   case '\n':   

    sb.Append("\\n"); break;   

   case '\r':   

    sb.Append("\\r"); break;   

   case '\t':   

    sb.Append("\\t"); break;   

   default:   

    sb.Append(c); break;   

  }   

 }   

 return sb.ToString();   

}   

  

/// <summary>   

/// 格式化字符型、日期型、布尔型   

/// </summary>   

/// <param name="str"></param>   

/// <param name="type"></param>   

/// <returns></returns>   

private static string StringFormat(string str, Type type)   

{   

 if (type == typeof(string))   

 {   

  str = String2Json(str);   

  str = "\"" + str + "\"";   

 }   

 else if (type == typeof(DateTime))   

 {   

  str = "\"" + str + "\"";   

 }   

 else if (type == typeof(bool))   

 {   

  str = str.ToLower();   

 }   

 return str;   

}

C#中任意类型数据转成JSON格式的更多相关文章

  1. 利用python将excel数据解析成json格式

    利用python将excel数据解析成json格式 转成json方便项目中用post请求推送数据自定义数据,也方便测试: import xlrdimport jsonimport requests d ...

  2. 用java代码将从数据库中取出的具有父子关系的数据转成json格式

    思路:①.取出数据中的所有父节点放入一个集合中②.取出数据中所有为该父节点的子节点放入另一个集合中③.用到迭代的方法将子节点一层一层的遍历工具类:package com.assasion.test;i ...

  3. flask框架下读取mysql数据 转换成json格式API

    研究了一天 因为需要从数据库拿数据然后转换成json的格式 expose出去为 API 发现一条数据是容易,两条以上我居然搞了这么久 好歹出来了 先贴一下 后面更新 mysql的操作 比较容易了htt ...

  4. Python中如何将数据存储为json格式的文件

    一.基于json模块的存储.读取数据 names_writer.py import json names = ['joker','joe','nacy','timi'] filename='names ...

  5. easyui获取table列表中所有数据组装成json格式发送到后台

    jsp代码 var rows =$('#findAllRolestable').datagrid('getSelections'); var result = JSON.stringify(rows) ...

  6. Python中如何将数据存储为json格式的文件(续)

    将上一篇中的例子,修改一下,将两个程序合二为一,如果存储了用户喜欢的水果就显示它,否则提示用户输入他喜欢的水果并将其存储到文件中. favorite.py import json filename = ...

  7. 【Flex】读取本地XML,然后XML数据转成JSON数据

    干了一年H5,最近被要求写编辑器,Electron等级还不够,写不了,只有重新拿起as3,用flex,最近写到数据表编辑模块,有这部分功能,基本完成 . package utils { /** * 模 ...

  8. C# 任意类型数据转JSON格式(转)

    HOT SUMMER 每天都是不一样,积极的去感受生活 C# 任意类型数据转JSON格式 /// <summary> /// List转成json /// </summary> ...

  9. DELPHI中枚举类型数据的介绍和使用方法

    在看delphi程序的时候看到aa=(a,b,c,d);这样的东西,还以为是数组,同事说是函数,呵呵,当然这两个都不屑一击,原来这样式子是在声明并付值一个枚举类型的数据.下边写下来DELPHI中枚举类 ...

随机推荐

  1. Android TV开发总结(五)TV上屏幕适配总结

    前言:前面几篇总结一些TV上的小Sample,开源到GitHub:https://github.com/hejunlin2013/TVSample, 点击链接,可以持续关注.今天总结下TV上屏幕适配. ...

  2. Apache shiro集群实现 (六)分布式集群系统下的高可用session解决方案---Session共享

    Apache shiro集群实现 (一) shiro入门介绍 Apache shiro集群实现 (二) shiro 的INI配置 Apache shiro集群实现 (三)shiro身份认证(Shiro ...

  3. 1.关于QT中json数据处理和密码md5加密

     新建一个Qt空项目 17Json.pro HEADERS += \ MyWidget.h SOURCES += \ MyWidget.cpp QT += widgets gui MyWidget ...

  4. Python模块探秘 Smtplib发送带有各种附件的邮件

    这两天对Python的邮件模块比较感兴趣,于是就查了查资料.同时在实际的编码过程中也遇到了各种各样的问题.下面我就来分享一下我与smtplib的故事. 前提条件 我的上一篇博文里面讲解了,发送邮件必须 ...

  5. T-SQL 中的CROSS JOIN用法(半翻译)

    突然发现个很吊的链接,我们来看看学习数据库要做些什么,胆小慎点:DBA工作内容!!!! 今天来翻译一篇关于T-SQL的文章,本文可供微软认证70-461:QueryingMicrosoft SQL S ...

  6. 两种配置大数据环境的方法Ambari以及hadoop源代码安装的步骤

    1.Ambari安装 Ambari & HDP(Hortonworks Data Platform) ********************************************* ...

  7. 收藏了4年的Android 源码分享

    Android 超过2个G的源代码集合~~几乎涵盖了所有功能效果的实现,一应俱全~~应有尽有~~ 360云盘地址:Android 各类源码集合汇总 (提取码:f930) 另外,附上Github上及自己 ...

  8. 深入剖析Tomcat会话机制

    1缓存机制 Tomcat默认将Session保存到内存中.但同时,Tomcat也提供了PersistentManager配合不同的Store实现的方式,使Session可以被保存到不同地方(Datab ...

  9. 动手实现linux中的cp命令(可自行拓展)

    我们在学习系统编程的时候,一定会有这样的经历,让你动手实现一个简单的cp命令,也就是拷贝相应的文件到对应的目录,或者说是复制吧,当然,实现非常的简单,我们来看看源码吧: #include <st ...

  10. SpringMVC源码分析--容器初始化(三)HttpServletBean

    在上一篇博客springMVC源码分析--容器初始化(二)DispatcherServlet中,我们队SpringMVC整体生命周期有一个简单的说明,并没有进行详细的源码分析,接下来我们会根据博客中提 ...