亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C# JSON格式化轉(zhuǎn)換輔助類(lèi) ConvertJson

 更新時(shí)間:2016年04月23日 12:05:42   作者:鄔興亮  
本文介紹使用C#原生代碼實(shí)現(xiàn) JSON格式化以及各種類(lèi)型轉(zhuǎn)化JSON的輔助類(lèi),幫助開(kāi)發(fā)人員快速開(kāi)發(fā)。

可能我們用慣了 Newtonsoft.Json.dll 等第三方的類(lèi)庫(kù)來(lái)實(shí)現(xiàn)序列化等類(lèi)似的操作,但是有時(shí)只是簡(jiǎn)單的用一下,感覺(jué)沒(méi)必要那么費(fèi)事,所謂殺雞焉用牛刀,自制個(gè)小刀即可。

代碼分享給大家,如下:

using System;
using System.Collections.Generic;
using System.Text;
using System.Data;
using System.Reflection;
using System.Collections;
using System.Data.Common;
 
public class ConvertJson
{
  #region 私有方法
  /// <summary>
  /// 過(guò)濾特殊字符
  /// </summary>
  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>
  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();
    }
    else if (type != typeof(string) && string.IsNullOrEmpty(str))
    {
      str = "\"" + str + "\"";
    }
    return str;
  }
  #endregion
 
  #region List轉(zhuǎn)換成Json
  /// <summary>
  /// List轉(zhuǎn)換成Json
  /// </summary>
  public static string ListToJson<T>(IList<T> list)
  {
    object obj = list[0];
    return ListToJson<T>(list, obj.GetType().Name);
  }
 
  /// <summary>
  /// List轉(zhuǎn)換成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 對(duì)象轉(zhuǎn)換為Json
  /// <summary>
  /// 對(duì)象轉(zhuǎn)換為Json
  /// </summary>
  /// <param name="jsonObject">對(duì)象</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 對(duì)象集合轉(zhuǎn)換Json
  /// <summary>
  /// 對(duì)象集合轉(zhuǎn)換Json
  /// </summary>
  /// <param name="array">集合對(duì)象</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 普通集合轉(zhuǎn)換Json
  /// <summary>
  /// 普通集合轉(zhuǎn)換Json
  /// </summary>
  /// <param name="array">集合對(duì)象</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轉(zhuǎn)換為Json
  /// <summary>
  /// DataSet轉(zhuǎn)換為Json
  /// </summary>
  /// <param name="dataSet">DataSet對(duì)象</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轉(zhuǎn)換為Json
  /// <summary>
  /// Datatable轉(zhuǎn)換為Json
  /// </summary>
  /// <param name="table">Datatable對(duì)象</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轉(zhuǎn)換為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轉(zhuǎn)換為Json
  /// <summary>
  /// DataReader轉(zhuǎn)換為Json
  /// </summary>
  /// <param name="dataReader">DataReader對(duì)象</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
}

相關(guān)文章

  • c#抽簽系統(tǒng)的實(shí)現(xiàn)示例

    c#抽簽系統(tǒng)的實(shí)現(xiàn)示例

    本文主要介紹了c#抽簽系統(tǒng)的實(shí)現(xiàn)示例,一個(gè)基于c#的簡(jiǎn)單抽簽系統(tǒng),可以重新導(dǎo)入數(shù)據(jù),清空數(shù)據(jù)。文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • DataGridView控件顯示行號(hào)的正確代碼及分析

    DataGridView控件顯示行號(hào)的正確代碼及分析

    今天要用到DataGridView,想給它動(dòng)態(tài)的顯示行號(hào)。于是在網(wǎng)上找了一下解決方法。結(jié)果發(fā)現(xiàn)了不少問(wèn)題。然而就是這么一段有錯(cuò)的代碼,幾乎充斥著整個(gè)互聯(lián)網(wǎng),千篇一律的COPY,沒(méi)有一個(gè)人糾正
    2013-08-08
  • 用 C# 編寫(xiě)一個(gè)停放在任務(wù)欄上的圖標(biāo)程序

    用 C# 編寫(xiě)一個(gè)停放在任務(wù)欄上的圖標(biāo)程序

    用 C# 編寫(xiě)一個(gè)停放在任務(wù)欄上的圖標(biāo)程序...
    2007-03-03
  • C#控制臺(tái)程序中處理2個(gè)關(guān)閉事件的代碼實(shí)例

    C#控制臺(tái)程序中處理2個(gè)關(guān)閉事件的代碼實(shí)例

    這篇文章主要介紹了C#控制臺(tái)程序中處理2個(gè)關(guān)閉事件的代碼實(shí)例,本文中的2個(gè)關(guān)閉事件是指Ctrl+C事件和窗口的關(guān)閉按鈕事件,需要的朋友可以參考下
    2014-09-09
  • C#基礎(chǔ)知識(shí) 全面解析可空類(lèi)型

    C#基礎(chǔ)知識(shí) 全面解析可空類(lèi)型

    C# 2.0 中還引入了可空類(lèi)型,可空類(lèi)型也是值類(lèi)型,只是可空類(lèi)型是包括null的值類(lèi)型的,下面就介紹下C#2.0中對(duì)可空類(lèi)型的支持具體有哪些內(nèi)容
    2012-11-11
  • C#實(shí)現(xiàn)將json轉(zhuǎn)換為DataTable的方法

    C#實(shí)現(xiàn)將json轉(zhuǎn)換為DataTable的方法

    這篇文章主要介紹了C#實(shí)現(xiàn)將json轉(zhuǎn)換為DataTable的方法,涉及C#操作json及DataTable的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-03-03
  • C#多線程之線程鎖

    C#多線程之線程鎖

    這篇文章介紹了C#多線程中的線程鎖,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-05-05
  • 一文看懂C#中List的擴(kuò)容機(jī)制

    一文看懂C#中List的擴(kuò)容機(jī)制

    這篇文章主要介紹了C#中的擴(kuò)容機(jī)制,文中以實(shí)例代碼輔助,幫助大家更好的工作和學(xué)習(xí),感興趣的小伙伴不妨了解下
    2020-05-05
  • 詳解C# List<T>的Contains,Exists,Any,Where性能對(duì)比

    詳解C# List<T>的Contains,Exists,Any,Where性能對(duì)比

    這篇文章主要介紹了詳解C# List<T>的Contains,Exists,Any,Where性能對(duì)比,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • C# Onnx實(shí)現(xiàn)特征匹配DeDoDe檢測(cè)

    C# Onnx實(shí)現(xiàn)特征匹配DeDoDe檢測(cè)

    這篇文章主要為大家詳細(xì)介紹了C# Onnx如何實(shí)現(xiàn)特征匹配DeDoDe檢測(cè),文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-11-11

最新評(píng)論