#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. [转]Openstack Havana Dashboard测试和使用

    转贴一篇陈沙克老师的文章:http://www.chenshake.com/openstack-havana-dashboard-to-test-and-use/ Openstack Havana D ...

  2. 74. Search a 2D Matrix

    题目: Write an efficient algorithm that searches for a value in an m x n matrix. This matrix has the f ...

  3. NSArray 利用数组创建数组

    NSArray *array=[NSArray arrayWithObjects:@"1",@"2",@"3", nil];         ...

  4. 前端自动化神器gulp使用记录

    1.安装压缩图片插件的时候,由于网络原因,死活安装不成功.由于imagemin本身就包含很多插件,安装的时候卡住了,很是郁闷.如果要压缩png图片,那就单独安装imagemin-pngquant压缩插 ...

  5. KMP入门题目[不定期更新]

    HDU 1711 Number Sequence(模板题) #include <cstdio> ; ; int N, M; int textS[MAXN]; int tarS[MAXL]; ...

  6. Size Classes with Xcode 6

    转载自 http://www.cocoachina.com/ios/20141015/9919.html 总结:通过在Size Classes不同的模式下设置,可以实现不同设备在横屏.竖屏下UIVie ...

  7. hibernate--关联映射(多对一,一对一)

    多对一 关联映射 --- many-to-one 场景:用户和组:从用户角度来,多个用户属于一个组(多对一 关联) 使用hibernate开发的思路:先建立对象模型(领域模型),把实体抽取出来. 目前 ...

  8. SQL复制表及表结构

    复制表结构和数据SQL语句 1:复制表结构及数据到新表 select * into 目的数据库名.dbo.目的表名 from 原表名 select * into my0735home.dbo.info ...

  9. js学习总结

    转自 http://blog.sina.com.cn/s/blog_75cf5f3201011csu.html 一: 关于基本数据类型在栈内存和堆内存中的关系 基本数据对于栈内存和堆内存是可以复制的, ...

  10. UVA 408 Uniform Generator 伪随机数(水)

    题意:根据这个式子来递推求得每个随机数x,step和mod给定,seed(0)=0.如果推出来的序列是mod个不重复的数字(0~mod-1)则打印good,否则bad(因为不能产生所有的数). 思路: ...