/// <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. 《Shazam It! Music Recognition Algorithms, Fingerprinting, and Processing》译文

    最近看到一篇老外写的博客,简单介绍了shazam的工作原理.图非常好,所以就把它翻译成中文,希望对搞听歌识曲的人有帮助. 你可能遇到这样的场景:在酒吧或者餐厅听到你非常熟悉的歌,也许你曾经听过无数次, ...

  2. RxJava(六) retryWhen操作符实现错误重试机制

    欢迎转载,转载请标明出处: http://blog.csdn.net/johnny901114/article/details/51539708 本文出自:[余志强的博客] 业务需求 当我们在app里 ...

  3. [LaTex]插图

    1.不错的Latex参考网站 http://www.ctex.org/documents/latex/graphics/node120.html http://www.ctex.org/documen ...

  4. activiti 数据库连接配置

    1.1.1. 前言 在activiti 动态配置 activiti 监听引擎启动和初始化(高级源码篇)一文中,我们讲解了如何动态的配置DataSource 当我们程序配置了DataSource,act ...

  5. Swift中不用桥接文件和.h头文件直接和C代码交互的方法

    我们知道一般情况下Swit要想调用obj-c,c或c++代码必须通过obj-c以及桥接文件才可以办到,但是对于某些简单的代码,我们可以跳过桥接文件和.h头文件,直接和C代码交互呢! 我们再Projec ...

  6. 高德地图车机版API演示程序

    高德地图车机版API演示程序 做车载的应该和这个程序打交道打的比较多吧,这里是我今天写的一个实现了他的API的一个演示程序 首先我们来看下他的官网. http://lbs.amap.com/api/a ...

  7. webstorm工具使用详解

    webstorm简单介绍 官网地址:http://www.jetbrains.com/webstorm/features/index.html 参考地址:http://www.html5jscss.c ...

  8. Android ListView中Item点击事件失效解决方案

    欢迎关注公众号,每天推送Android技术文章,二维码如下:(可扫描) 在平常的开发过程中,我们的ListView可能不只是简单的显示下文本或者按钮,更多的是显示复杂的布局,这样的话,我们就得自己写布 ...

  9. little kernel中如何决定app目录下应该包含哪个app

    lk中是会为每个app建立一个thread,所以的app都是放在app这个路径下,那是在哪里决定的呢?一般是通过在project下面的MODULE决定的,例如下面这个例子就只用app下面的aboot这 ...

  10. java异常体系结构详解

    前几天在参加网易和360公司的在线考试的时候,都出了一道关于java中异常类的多项选择题.这几天翻看了相关书籍和网上一些资料,结合自己的理解与思考,将自己的一些收获记录如下: 先来看看java中异常的 ...