• List转换成Json、对象集合转换Json等


    #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

    佛为心,道为骨,儒为表,大度看世界; 技在手,能在身,思在脑,从容过生活; 三千年读史,不外功名利禄; 九万里悟道,终归诗酒田园;
  • 相关阅读:
    PTA(Basic Level)1048.数字加密
    PTA(Basic Level)1037.在霍格沃茨找零钱
    PTA(Basic Level)1030.完美数列
    PTA(Basic Level)1047.编程团体赛
    PTA(Basic Level)1087.有多少不同的值
    PTA(Basic Level)1077.互评成绩计算
    PTA(Basic Level)1027.打印沙漏
    PTA(Basic Level)1029.旧键盘
    记录一次排查挖矿:快速跟踪一个进程
    JVM性能、多线程排查常用命令
  • 原文地址:https://www.cnblogs.com/taofx/p/4137699.html
Copyright © 2020-2023  润新知