/// <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系统上写C语言程序--开机启动该程序不进入安卓系统

    今天要写的这篇博文意义重大,也是网上很少有的,这是在我工作中学会的一项技术,当然,它也是由简单的问题组合而来的.如何在安卓中写C语言程序,调试安卓驱动,测试程序的的一项重要技能,下面我就不说废话了,直 ...

  2. Protobuf-net判断字段是否有值

    Protobuf-net判断字段是否有值Unity3d使用Protobuf-net序列化数据与服务器通信,但是发现默认情况下,Protobuf-net生成的cs文件中没有接口判断可选参数是否有值.需有 ...

  3. SQL Server 执行计划操作符详解(3)——计算标量(Compute Scalar)

    接上文:SQL Server 执行计划操作符详解(2)--串联(Concatenation ) 前言: 前面两篇文章介绍了关于串联(Concatenation)和断言(Assert)操作符,本文介绍第 ...

  4. 从操作系统内核看Java非阻塞IO事件检测

    非阻塞服务器模型最重要的一个特点是,在调用读取或写入接口后立即返回,而不会进入阻塞状态.在探讨单线程非阻塞IO模型前必须要先了解非阻塞情况下Socket事件的检测机制,因为对于非阻塞模式最重要的事情是 ...

  5. FFmpeg源代码简单分析:avformat_write_header()

    ===================================================== FFmpeg的库函数源代码分析文章列表: [架构图] FFmpeg源代码结构图 - 解码 F ...

  6. jar包执行报ClassNotFoundException

    使用Eclipse打包jar包,指定了main class. java -jar mongoCluster.jar 但是运行的时候报ClassNotFoundException NoClassDefF ...

  7. CentOS一般用户和root用户之间的切换

    如果终端提示符显示为"$",表明该用户为普通用户.输入su,回车,然后输入root密码,即可切换到root用户.如果是root用户想切换回普通用户,输入"su 用户名&q ...

  8. 使用Geolocation校正GDAL不支持的数据

    对于低分数据来说,常用的校正方式就是给定数据的经纬度查找表来进行校正.在GDAL中,这种校正方式叫Geolocation array.常用的数据有国外的MODIS数据,国内的如风云系列(FY)和海洋系 ...

  9. iOS让软键盘消失的简单方法

    大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请多提意见,如果觉得不错请多多支持点赞.谢谢! hopy ;) 一些文本输入控件等待输入时会弹出软键盘,我们可以设置这些控件的 ...

  10. scala学习笔记3(trait)

    // trait 类似于 Java8 中可以带 default method 的接口. // trait 中可以带有实现的方法,也可以带有抽象的方法,使用 trait 的方式是 with 而混入类中 ...