Daten mit linq [duplizieren] pivoten

Diese Frage hat hier bereits eine Antwort:

Ist es möglich, Daten mit LINQ zu pivoten? 6 Antworten

Ich habe folgende Klassenstruktur:

 public class TaskLog
 {
    public DateTime LogDate { get; set; }
    public string Robot { get; set; }
    public string Task { get; set; }
    public Enums.ProbeDataState State { get; set; }

    public TaskLog()
    {
    }
}

Ich habe eine allgemeine Liste wie folgt erstellt:

List<TaskLog> Logs;

Meine Ausgabe:

Robot   Date                    State
---------------------------------------------
aaa     8/5/2013 12:00:00 AM    Task:1=fileDeltaFailed
aaa     8/5/2013 12:00:00 AM    Task:2=fileDeltaFailed
aaa     8/5/2013 12:00:00 AM    Task:4=fileDeltaFailed
bbb     8/5/2013 12:00:00 AM    Task:1=fileDeltaFailed
bbb     8/5/2013 12:00:00 AM    Task:2=fileDeltaFailed
bbb     8/5/2013 12:00:00 AM    Task:4=fileDeltaFailed

Ich möchte die Aufgaben jedoch wie folgt gruppieren und angeben:

                                Tasks
Robot   Date                    1                 2                4
aaa     8/5/2013 12:00:00 AM    fileDeltaFailed   fileDeltaFailed  fileDeltaFailed 
bbb     8/5/2013 12:00:00 AM    fileDeltaFailed   fileDeltaFailed  fileDeltaFailed

Ich habe versucht, die Gruppe ohne Glück zu benutzen, und bin ziemlich festgefahren.

z.B.

 var dataQuery = Logs.Where(w => w.LogDate >= start && w.LogDate <= finish).GroupBy(g => g.LogDate).Select(t => new
            {
                LogDate = t.Key,
                Details = t.OrderBy(o => o.Robot)
            }).ToList();

Antworten auf die Frage(3)

Ihre Antwort auf die Frage