zoukankan      html  css  js  c++  java
  • IListHelper 实现IList到DataSet和DataTable的数据转换

    /// <summary>
        
    /// List Transfer DataTable Class
        
    /// </summary>

        public class IListHelper
        
    {
            
    /// <summary>
            
    /// Ilist<T> Transfer DataSet
            
    /// </summary>
            
    /// <param name="i_objlist"></param>
            
    /// <returns></returns>

            public static DataSet ConvertToDataSet<T>(IList<T> i_objlist)
            
    {
                
    if (i_objlist == null || i_objlist.Count <= 0)
                
    {
                    
    return null;
                }
     
                DataSet ds 
    = new DataSet();
                DataTable dt 
    = new DataTable(typeof(T).Name);
                DataColumn column;
                DataRow row;

                System.Reflection.PropertyInfo[] myPropertyInfo 
    = typeof(T).GetProperties(System.Reflection.BindingFlags.Public | System.Reflection.BindingFlags.Instance);

                
    foreach (T t in i_objlist)
                
    {
                    
    if (t == null)
                    
    {
                        
    continue;
                    }


                    row 
    = dt.NewRow();

                    
    for (int i = 0, j = myPropertyInfo.Length; i < j; i++)
                    
    {
                        System.Reflection.PropertyInfo pi 
    = myPropertyInfo[i];

                        
    string name = pi.Name;

                        
    if (dt.Columns[name] == null)
                        
    {
                            column 
    = new DataColumn(name, pi.PropertyType);
                            dt.Columns.Add(column);
                        }


                        row[name] 
    = pi.GetValue(t, null);
                    }


                    dt.Rows.Add(row);
                }


                ds.Tables.Add(dt);

                
    return ds;
            }


            
    /// <summary>
            
    /// Ilist<T> Transfer DataTable
            
    /// </summary>
            
    /// <param name="i_objlist"></param>
            
    /// <returns></returns>

            public static DataTable ConvertToDataTable<T>(IList<T> i_objlist)
            
    {
                
    if (i_objlist == null || i_objlist.Count <= 0)
                
    {
                    
    return null;
                }

                DataTable dt 
    = new DataTable(typeof(T).Name);
                DataColumn column;
                DataRow row;

                System.Reflection.PropertyInfo[] myPropertyInfo 
    = typeof(T).GetProperties(System.Reflection.BindingFlags.Public | System.Reflection.BindingFlags.Instance);

                
    foreach (T t in i_objlist)
                
    {
                    
    if (t == null)
                    
    {
                        
    continue;
                    }


                    row 
    = dt.NewRow();

                    
    for (int i = 0, j = myPropertyInfo.Length; i < j; i++)
                    
    {
                        System.Reflection.PropertyInfo pi 
    = myPropertyInfo[i];

                        
    string name = pi.Name;

                        
    if (dt.Columns[name] == null)
                        
    {
                            column 
    = new DataColumn(name, pi.PropertyType);
                            dt.Columns.Add(column);
                        }


                        row[name] 
    = pi.GetValue(t, null);
                    }


                    dt.Rows.Add(row);
                }

                
    return dt;
            }

            
    /// <summary>
            
    /// Ilist Transfer DataTable
            
    /// </summary>
            
    /// <param name="i_objlist"></param>
            
    /// <returns></returns>

            public static DataTable ConvertToDataTable(IList i_objlist)
            
    {
                
    if (i_objlist == null || i_objlist.Count <= 0)
                
    {
                    
    return null;
                }

                DataTable dt 
    = new DataTable();
                DataRow row;

                System.Reflection.PropertyInfo[] myPropertyInfo 
    = i_objlist[0].GetType().GetProperties();

                
    foreach (System.Reflection.PropertyInfo pi in myPropertyInfo)
                
    {
                    
    if (pi == null)
                    
    {
                        
    continue;
                    }

                    dt.Columns.Add(pi.Name, System.Type.GetType(pi.PropertyType.ToString()));
                }

                
    for (int j = 0; j < i_objlist.Count; j++)
                
    {
                    row 
    = dt.NewRow();
                    
    for (int i = 0; i < myPropertyInfo.Length; i++)
                    
    {
                        System.Reflection.PropertyInfo pi 
    = myPropertyInfo[i];
                        row[pi.Name] 
    = pi.GetValue(i_objlist[j], null);
                    }

                    dt.Rows.Add(row);
                }

                
    return dt;
            }


            
    /// <summary>
            
    /// Ilist Transfer DataSet
            
    /// </summary>
            
    /// <param name="i_objlist"></param>
            
    /// <returns></returns>

            public static DataSet ConvertToDataSet(IList i_objlist)
            
    {
                
    if (i_objlist == null || i_objlist.Count <= 0)
                
    {
                    
    return null;
                }

                DataSet ds 
    = new DataSet();
                DataTable dt 
    = new DataTable();
                DataRow row;

                System.Reflection.PropertyInfo[] myPropertyInfo 
    = i_objlist[0].GetType().GetProperties();

                
    foreach (System.Reflection.PropertyInfo pi in myPropertyInfo)
                
    {
                    
    if (pi == null)
                    
    {
                        
    continue;
                    }

                    dt.Columns.Add(pi.Name, System.Type.GetType(pi.PropertyType.ToString()));
                }

                
    for (int j = 0; j < i_objlist.Count; j++)
                
    {
                    row 
    = dt.NewRow();
                    
    for (int i = 0; i < myPropertyInfo.Length; i++)
                    
    {
                        System.Reflection.PropertyInfo pi 
    = myPropertyInfo[i];
                        row[pi.Name] 
    = pi.GetValue(i_objlist[j], null);
                    }

                    dt.Rows.Add(row);
                }

                ds.Tables.Add(dt);
                
    return ds;
            }

        }
  • 相关阅读:
    二分练习题4 查找最接近的元素 题解
    二分练习题5 二分法求函数的零点 题解
    二分练习题3 查找小于x的最大元素 题解
    二分练习题2 查找大于等于x的最小元素 题解
    二分练习题1 查找元素 题解
    code forces 1176 D. Recover it!
    code forces 1173 B. Nauuo and Chess
    code forces 1173 C. Nauuo and Cards
    吴恩达深度学习课程笔记-15
    吴恩达深度学习课程笔记-14
  • 原文地址:https://www.cnblogs.com/adam/p/891324.html
Copyright © 2011-2022 走看看