/// <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 5.0新控件——TextInputLayout

    Android 5.0(M)新控件--TextInputLayout 介绍之前,先直观的看一下效果 TextInputLayout其实是一个容器,他继承自LinearLayout,该容器是作用于Tex ...

  2. 《高性能MySQL》读书笔记(上)

    <High Performance MySQL>真是本经典好书,从应用层到数据库到硬件平台,各种调优技巧.常见问题全都有所提及.数据库的各种概念技巧平时都有接触,像索引.分区.Shardi ...

  3. 【美工设计 - Adobe Illustrator】基本设置 (图像显示 | 图像缩放 | 置入导出 | 标尺 | 网格 | 参考线 | 画板)

    作者 : 韩曙亮 转载请注明出处 : http://blog.csdn.net/shulianghan/article/details/50232767 一. 基础操作 1. 设置图像显示效果 (1) ...

  4. 带吸附效果的ViewPager(二)

    上篇实现了一个简单的吸附效果,那么这篇我们来实现上篇中所示的360软件详情页(带viewpager)的效果!先来参观下本篇所实现的效果图: 了解了上一篇的实现过程,那么本篇的效果无非是修改一下布局,将 ...

  5. (八十七)AutoLayout的简介与实例

    AutoLayout是继AutoResizing之后的一种自动布局方法,解决了AutoResizing无法处理控件间相互关系的问题. AutoLayout在storyboard中通过底部工具条设置,底 ...

  6. 【一天一道LeetCode】#121. Best Time to Buy and Sell Stock

    # 一天一道LeetCode 本系列文章已全部上传至我的github,地址:ZeeCoder's Github 欢迎大家关注我的新浪微博,我的新浪微博 欢迎转载,转载请注明出处 (一)题目 Say ...

  7. Web开发的发展史

    英文出处:arunr.欢迎加入翻译小组. 导读:Arunr 把过去 15 年以来,Web开发从最初的纯 HTML 到 CGI.PHP\JSP\ASP.Ajax.Rails.NodeJS 这个过程简要地 ...

  8. MySQL数据库内置函数

    mysql数据库中提供了很丰富的函数.mysql函数包括数学函数.字符串函数.日期和时间函数.条件判断函数.系统信息函数.加密函数.格式化函数等.通过这些函数,可以简化用户的操作. 简单介绍几类函数的 ...

  9. 1021. Deepest Root (25) -并查集判树 -BFS求深度

    题目如下: A graph which is connected and acyclic can be considered a tree. The height of the tree depend ...

  10. JavaScript压缩工具JSA使用介绍

    JavaScript压缩工具JSA使用介绍 JSA绝对是我使用过的JS压缩工具中最上乘的一个.认识它是从ligerUI开始.在ligerUI的QQ讨论组里,大神--ligerUI的作者告诉我他的lig ...