• 将DataTable或Ilist<>转换成JSON格式


    using System;
    using System.Data;
    using System.Text;
    using System.Collections.Generic;
    using System.Reflection;

    /// <summary>
    /// 将DataTable或Ilist<>转换成JSON格式
    /// </summary>
    public class ToJson
    {
        
    public ToJson()
        {

        }

    //DataTable转成Json
        public static string DataTableToJson(string jsonName, DataTable dt)
        {
            StringBuilder Json 
    = new StringBuilder();
            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++)
                    {
                        Json.Append(
    "\"" + dt.Columns[j].ColumnName.ToString() + "\":\"" + dt.Rows[i][j].ToString() + "\"");
                        
    if (j < dt.Columns.Count - 1)
                        {
                            Json.Append(
    ",");
                        }
                    }
                    Json.Append(
    "}");
                    
    if (i < dt.Rows.Count - 1)
                    {
                        Json.Append(
    ",");
                    }
                }
            }
            Json.Append(
    "]}");
            
    return Json.ToString();
        }

    //List转成json
        public static string ObjectToJson<T>(string jsonName, IList<T> IL)
        {
            StringBuilder Json 
    = new StringBuilder();
            Json.Append(
    "{\"" + jsonName + "\":[");
            
    if (IL.Count > 0)
            {
                
    for (int i = 0; i < IL.Count; i++)
                {
                    T obj 
    = Activator.CreateInstance<T>();
                    Type type 
    = obj.GetType();
                    PropertyInfo[] pis 
    = type.GetProperties();
                    Json.Append(
    "{");
                    
    for (int j = 0; j < pis.Length; j++)
                    {
                        Json.Append(
    "\"" + pis[j].Name.ToString() + "\":\"" + pis[j].GetValue(IL[i], null) + "\"");
                        
    if (j < pis.Length - 1)
                        {
                            Json.Append(
    ",");
                        }
                    }
                    Json.Append(
    "}");
                    
    if (i < IL.Count - 1)
                    {
                        Json.Append(
    ",");
                    }
                }
            }
            Json.Append(
    "]}");
            
    return Json.ToString();
        }
    }

    程序员搜索工具:http://www.openso.net/

  • 相关阅读:
    Android 中的 Service 全面总结
    数据库事务
    ADB server didn't ACK
    Eclipse中10个最有用的快捷键组合
    IoC框架
    Wifi相关的操作
    Hibernate generator小结
    不朽的青春
    JSCPC 2020 摸鱼记
    CCPC 2020 秦皇岛站 H题
  • 原文地址:https://www.cnblogs.com/nba4523/p/1368858.html
Copyright © 2020-2023  润新知