Home Backend Development C#.Net Tutorial Implementation code for converting DataSet, string, DataTable, and objects in C# into Json

Implementation code for converting DataSet, string, DataTable, and objects in C# into Json

Jan 18, 2017 am 09:38 AM

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

public class ConvertJson
 {
  #region 私有方法
  /// <summary>
  /// 过滤特殊字符
  /// </summary>
  /// <param name="s">字符串</param>
  /// <returns>json字符串</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 &#39;\"&#39;:
      sb.Append("\\\""); break;
     case &#39;\\&#39;:
      sb.Append("\\\\"); break;
     case &#39;/&#39;:
      sb.Append("\\/"); break;
     case &#39;\b&#39;:
      sb.Append("\\b"); break;
     case &#39;\f&#39;:
      sb.Append("\\f"); break;
     case &#39;\n&#39;:
      sb.Append("\\n"); break;
     case &#39;\r&#39;:
      sb.Append("\\r"); break;
     case &#39;\t&#39;:
      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();
   }
   else if (type != typeof(string) && string.IsNullOrEmpty(str))
   {
    str = "\"" + str + "\"";
   }
   return str;
  }
  #endregion
 
  #region list转换成JSON
  /// <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>
  /// list转换为json
  /// </summary>
  /// <typeparam name="T1"></typeparam>
  /// <param name="list"></param>
  /// <param name="p"></param>
  /// <returns></returns>
  private 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">json对象</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 = "&#39;" + objectValue.ToString() + "&#39;";
    }
    else if (objectValue is string)
    {
     value = "&#39;" + ToJson(objectValue.ToString()) + "&#39;";
    }
    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(&#39;,&#39;);
   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
 }
Copy after login

更多C#中的DataSet、string、DataTable、对象转换成Json的实现代码相关文章请关注PHP中文网!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
2 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Repo: How To Revive Teammates
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: How To Get Giant Seeds
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

What are the alternatives to NULL in C language What are the alternatives to NULL in C language Mar 03, 2025 pm 05:37 PM

This article explores the challenges of NULL pointer dereferences in C. It argues that the problem isn't NULL itself, but its misuse. The article details best practices for preventing dereferences, including pre-dereference checks, pointer initiali

How to add next-level C compiler How to add next-level C compiler Mar 03, 2025 pm 05:44 PM

This article explains how to create newline characters in C using the \n escape sequence within printf and puts functions. It details the functionality and provides code examples demonstrating its use for line breaks in output.

Which C language compiler is better? Which C language compiler is better? Mar 03, 2025 pm 05:39 PM

This article guides beginners on choosing a C compiler. It argues that GCC, due to its ease of use, wide availability, and extensive resources, is best for beginners. However, it also compares GCC, Clang, MSVC, and TCC, highlighting their differenc

Is NULL still important in modern programming in C language? Is NULL still important in modern programming in C language? Mar 03, 2025 pm 05:35 PM

This article emphasizes the continued importance of NULL in modern C programming. Despite advancements, NULL remains crucial for explicit pointer management, preventing segmentation faults by marking the absence of a valid memory address. Best prac

What are the web versions of C language compilers? What are the web versions of C language compilers? Mar 03, 2025 pm 05:42 PM

This article reviews online C compilers for beginners, focusing on ease of use and debugging capabilities. OnlineGDB and Repl.it are highlighted for their user-friendly interfaces and helpful debugging tools. Other options like Programiz and Compil

Method of copying code by C language compiler Method of copying code by C language compiler Mar 03, 2025 pm 05:43 PM

This article discusses efficient code copying in C IDEs. It emphasizes that copying is an IDE function, not a compiler feature, and details strategies for improved efficiency, including using IDE selection tools, code folding, search/replace, templa

C language online programming website C language compiler official website summary C language online programming website C language compiler official website summary Mar 03, 2025 pm 05:41 PM

This article compares online C programming platforms, highlighting differences in features like debugging tools, IDE functionality, standard compliance, and memory/execution limits. It argues that the "best" platform depends on user needs,

How to solve the problem of not popping up the output window by the C language compiler How to solve the problem of not popping up the output window by the C language compiler Mar 03, 2025 pm 05:40 PM

This article troubleshoots missing output windows in C program compilation. It examines causes like failing to run the executable, program errors, incorrect compiler settings, background processes, and rapid program termination. Solutions involve ch

See all articles