2009-11-18 8 views
7

개체 모음을 "피벗"또는 "회전"해야했습니다.IEnumerable 피벗 방법 <T>

/// <summary>Converts an IEnumerable into a pivoted DataTable object.</summary> 
/// <param name="collection">The IEnumerable object to pivot and convert.</param> 
/// <param name="headingMember">The name of a public field or property member of type T to be used as column name's in the pivoted DataTable object.</param> 
/// <param name="membersHeading">The name of the column that lists the public fields and properties of type T.</param>   
static DataTable Pivot<T>(this IEnumerable<T> collection, string headingMember, string membersHeading) 
{ 
    // get object information 
    var type = typeof(T); 
    var members = new List<MemberInfo>(); 
    members.AddRange(type.GetProperties(BindingFlags.Public | BindingFlags.Instance)); 
    members.AddRange(type.GetFields(BindingFlags.Public | BindingFlags.Instance)); 

    // create dataTable and establish schema 
    var dt = new DataTable(); 
    dt.Columns.Add(membersHeading); 
    foreach (var item in collection) 
    { 
     var member = members.Single(x => x.Name == headingMember); 
     if (member is FieldInfo)       
     { 
      FieldInfo fieldInfo = (FieldInfo)member; 
      dt.Columns.Add(fieldInfo.GetValue(item).ToString(), fieldInfo.FieldType); 
     } 

     if (member is PropertyInfo) 
     { 
      PropertyInfo propInfo = (PropertyInfo)member; 
      dt.Columns.Add(propInfo.GetValue(item, null).ToString(), propInfo.PropertyType); 
     } 
    } 

    // add rows to table 
    foreach (MemberInfo member in members.Where(x => x.Name != headingMember)) 
    { 
     var row = dt.NewRow(); 
     row[0] = member.Name; 
     int i = 1; 

     foreach (var item in collection) 
     { 
      if (member is FieldInfo) 
       row[i++] = ((FieldInfo)member).GetValue(item); 

      if (member is PropertyInfo) 
       row[i++] = ((PropertyInfo)member).GetValue(item, null); 
     } 

     dt.Rows.Add(row); 
    } 

    return dt; 
} 

은 무엇이 할 수있는 더 좋은 방법이 될 것입니다 : 여기

var people = new List<Person>(new[] { 
       new Person{ Name="Ronnie",Age=25, HairColor="Brown",EyeColor="Blue"}, 
       new Person{ Name="Tina",Age=25, HairColor="Brown",EyeColor="Green"}, 
       new Person{ Name="Lukus",Age=4, HairColor="Blonde",EyeColor="Blue"}  
      }); 

DataTable rotatedData = people.Pivot("Name", "Property");     

/* Results In: 
* ___________________________________________ 
* Property | Ronnie | Tina | Lukus 
* ___________________________________________ 
* Age  | 25  | 25  | 4 
* HairColor | Brown | Brown | Blonde 
* EyeColor | Blue | Green | Blue 
* ____________________________________________ 
*/ 

내가이를 작성한 코드입니다 : 예는 내가 할 필요가 무엇인지 정리한다 ?

+0

이것은 많은 질문 (피벗 linq 검색)의 중복입니다. – jason

+0

내가 물어보기 전에 했어. –

답변

1

단순히 이름에 Group을 사용하여 IEnumerable을 피벗 할 수 있습니다. 이름이 뚜렷하다고 가정합니다. 데이터를 피봇 팅하면 Convert IEnumerable to DataTable 수 있습니다.

+0

코드 샘플을 제공 할 수 있습니까? – Lucas

관련 문제