#region List转换成Json

/// <summary>

/// List转换成Json

/// </summary>

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

{

object obj = list[0];

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

}

/// <summary>

/// List转换成Json

/// </summary>

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();

}

#endregion

#region 对象转换为Json

/// <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 + "}";

}

#endregion

#region 对象集合转换Json

/// <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 + "]";

}

#endregion

#region 普通集合转换Json

/// <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 + "]";

}

#endregion

#region  DataSet转换为Json

/// <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 + "}";

}

#endregion

#region Datatable转换为Json

/// <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>

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();

}

#endregion

#region DataReader转换为Json

/// <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();

}

#endregion

List转换成Json、对象集合转换Json等的更多相关文章

  1. C#中对象,字符串,dataTable、DataReader、DataSet,对象集合转换成Json字符串方法。

    C#中对象,字符串,dataTable.DataReader.DataSet,对象集合转换成Json字符串方法. public class ConvertJson { #region 私有方法 /// ...

  2. JSON转换类(二)--List转换成Json、对象集合转换Json等

    #region List转换成Json /// <summary> /// List转换成Json /// </summary> public static string Li ...

  3. Java对象转换成xml对象和Java对象转换成JSON对象

    1.把Java对象转换成JSON对象 apache提供的json-lib小工具,它可以方便的使用Java语言来创建JSON字符串.也可以把JavaBean转换成JSON字符串. json-lib的核心 ...

  4. json字符串转换成json对象,json对象转换成字符串,值转换成字符串,字符串转成值

    一.json相关概念 json,全称为javascript object notation,是一种轻量级的数据交互格式.采用完全独立于语言的文本格式,是一种理想的数据交换格式. 同时,json是jav ...

  5. json字符串转json对象,json对象转换成java对象

    @RequestMapping(value = "updateInvestorApplyAccountNo", method = RequestMethod.POST) @Resp ...

  6. json中把非json格式的字符串转换成json对象再转换成json字符串

    JSON.toJson(str).toString()假如key和value都是整数的时候,先转换成jsonObject对象,再转换成json字符串

  7. Razor 将C#对象转换成Javascript对象, json还原被转码的字符 &quot·· HTML转义符

    Razor 将C#对象转换成Javascript对象 在Razor中使用Json字符串,特殊字符被自动转义(如:\"->") @{ var jsonStr = Html.Ra ...

  8. json字符串转成 json对象 json对象转换成java对象

    import com.alibaba.fastjson.JSONArray;import com.alibaba.fastjson.JSONObject; 依赖包 <dependency> ...

  9. [Json] C#ConvertJson|List转成Json|对象|集合|DataSet|DataTable|DataReader转成Json (转载)

    点击下载 ConvertJson.rar 本类实现了 C#ConvertJson|List转成Json|对象|集合|DataSet|DataTable|DataReader转成Json|等功能大家先预 ...

随机推荐

  1. 荣耀3X畅玩版狙击红米note!

    华为与小米的战争史,可以追溯到 红米 799,华为独立初荣耀品牌推出荣耀3C,定价798,就是比你少一快; 小米3 定价1999,华为出荣耀3X,定价1980; 最近的红米Note,标配版定价799, ...

  2. vector、string实现大数加法乘法

    理解 vector 是一个容器,是一个数据集,里边装了很多个元素.与数组最大的不同是 vector 可以动态增长. 用 vector 实现大数运算的关键是,以 string 的方式读入一个大数,然后将 ...

  3. lintcode :Ugly Numbers 丑数

    题目 丑数 设计一个算法,找出只含素因子3,5,7 的第 k 大的数. 符合条件的数如:3,5,7,9,15...... 样例 如果k=4, 返回 9 挑战 要求时间复杂度为O(nlogn)或者O(n ...

  4. python 处理 Excel 表格

    see: http://www.cnblogs.com/sunada2005/p/3193300.html 一.可使用的第三方库 python中处理excel表格,常用的库有xlrd(读excel)表 ...

  5. iOS使用Charts框架绘制—柱形图

    首先看一下最终要实现的效果: 最终效果 一.初始化barChartView 绘制柱形图需要用到BarChartView这个类,下面是初始化代码: self.barChartView = [[BarCh ...

  6. React Jest测试

    一. var jest = require('jest'); jest.dontMock('../CheckboxWithLabel.js'); describe('CheckboxWithLabel ...

  7. iOS xcuserdata

    说明:       project.xcworkspace说明:is a directory of files describing the workspace or projects. Althou ...

  8. MyEclipse 2014GA 新建 Web Project 并配置 SSH

    基本软件配置:     1)MyEclipse 2014GA(JDK:内置 1.7.0.u45:SSH:内置 Struts2.1.Spring3.1 和 Hibernate4.1) 2)apache- ...

  9. 《数据通信与网络》笔记--TCP中的拥塞控制

    1.拥塞窗口 发送方窗口的大小不仅取决于接收方,而.而且还取决于网络拥塞的情况. 发送方有2种信息:接收方通告的窗口大小和拥塞窗口的大小,实际的窗口大小事这两者中的最小者. 实际窗口大小 = min( ...

  10. windows/ubuntu 文件共享之 Samba 配置

    很多时候需要在windows上和ubuntu 上共享文件,一直没怎么去找方法,得知Samba 可以实现在windows上访问linux的文件,这样一来要从windows文件放到linux中就方便了,听 ...