/// <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艺术开发探索第四章——View的工作原理(下)

    Android艺术开发探索第四章--View的工作原理(下) 我们上篇BB了这么多,这篇就多多少少要来点实战了,上篇主席叫我多点自己的理解,那我就多点真诚,少点套路了,老司机,开车吧! 我们这一篇就扯 ...

  2. 下载Android源代码编译错误总结

    错误1: prebuilts/sdk/api/18.txt:22055: error 9: Removed public method android.telephony.gsm.SmsMessage ...

  3. 【学习笔记】启动Nginx、查看nginx进程、查看nginx服务主进程的方式、Nginx服务可接受的信号、nginx帮助命令、Nginx平滑重启、Nginx服务器的升级

     1.启动nginx的方式: cd /usr/local/nginx ls ./nginx -c nginx.conf 2.查看nginx的进程方式: [root@localhost nginx] ...

  4. 论Android代码加固的意义和hook

    加固的意义 从安卓2.x版本起,加固技术就逐渐火了起来.最初,只有一些创业型公司涉及加固领域:随着安卓应用的逐渐升温,诸如阿里.腾讯.百度等大型互联网公司逐渐涉及该领域. 那么为什么要对APP进行加固 ...

  5. Erlang简单并行服务器

    Erlang简单并行服务器(金庆的专栏)Erlang并行服务器为每个Tcp连接创建对应的连接进程,处理客户端数据.参考 Erlang程序设计(第2版)17.1.3 顺序和并行服务器并行服务器的诀窍是: ...

  6. UE4联机烘焙

    联机烘焙就是为了利用多台电脑解决烘焙效率的问题 1.UE4的烘焙工具在安装目录下的\Engine\Binaries\DotNET,比如我这里是E:\UnrealEngine-release\Engin ...

  7. UNIX网络编程——Socket通信原理和实践

    我们深谙信息交流的价值,那网络中进程之间如何通信,如我们每天打开浏览器浏览网页时,浏览器的进程怎么与web服务器通信的?当你用QQ聊天时,QQ进程怎么与服务器或你好友所在的QQ进程通信?这些都得靠so ...

  8. Android开发学习之路--Activity之生命周期

    其实这篇文章应该要在介绍Activity的时候写的,不过那个时候还不怎么熟悉Activity,还是在这里详细介绍下好了.还是参考下官方文档的图吧: 从上面的流程,我们可以看出首先就是打开APP,开始执 ...

  9. 网站开发进阶(四十二)巧用clear:both

    网站开发进阶(四十二)巧用clear:both 前言 我们在制作网页中用div+css或者称xhtml+css都会遇到一些很诡异的情况,明明布局正确,但是整个画面却混乱起来了,有时候在IE6下看的很正 ...

  10. 我的第二个独立开发的邮箱类App—“简邮”(支持QQ、雅虎、阿里云、Outlook)

    360手机市场地址: 360市场 其它市场还在审核,囧... 为什么做这个App? 主要有两个原因 1.10月份正逢校招季,--当时和面试官介绍了这个APP 2.在苹果手机上看到一款内置的邮箱app支 ...