返回匿名IEnumerable的IGrouping以呈现在DataGrid上

时间:2016-01-10 19:00:36

标签: c# wpf linq datagrid igrouping

在WPF上我构建了这段代码 我想在datagrid上显示" Desc"的总和。对于每个" PID"

public class Event
{
    public int PID { get; set; }
    public int Desc { get; set; }
}

private List<Event> data;
public MainWindow()
{
    InitializeComponent();
    data = new List<Event>() 
    {
        new Event() { PID = 1, Desc=2 },
        new Event() { PID = 1, Desc=3 },
        new Event() { PID = 2, Desc=4 },
        new Event() { PID = 2, Desc=5 },
        new Event() { PID = 3, Desc=6 }
    };

    var result =
        from d in data
        group d.Desc by d.PID into pg
        select new { ID = pg.Key,  SUM = pg.Sum() };

    datagrid.ItemsSource = result;
}

XAML是

<DataGrid Name="datagrid" AutoGenerateColumns="False" IsReadOnly="True">
    <DataGrid.Columns>
        <DataGridTextColumn Header="id" Binding="{Binding ID}" Width="*"/>
        <DataGridTextColumn Header="Name" Binding="{Binding SUM}" Width="*"/>
    </DataGrid.Columns>
</DataGrid>

运作良好! 但这不好,

我想要做的是返回&#34; var result&#34;从功能和绑定,就像我对DataGrid 我怎么能这样做?

这来自IEnumerable<IGrouping<int,???>> 上 ???有匿名类型......

那么如何从函数和绑定中返回这个,就像我在DataGrid上做的那样?

谢谢!

1 个答案:

答案 0 :(得分:1)

您需要一个类来表示序列中的每个项目。这样,您的结果将不是匿名类型的对象序列,但它将是特定类型的对象序列。

public class Result 
{
    public int Id { get; set;}
    public int Sum { get; set; }
}

然后您将定义如下方法:

public IEnumerable<Result> GetResults()
{
    data = new List<Event>() 
    {
        new Event() { PID = 1, Desc=2 },
        new Event() { PID = 1, Desc=3 },
        new Event() { PID = 2, Desc=4 },
        new Event() { PID = 2, Desc=5 },
        new Event() { PID = 3, Desc=6 }
    };

    var result = from d in data
                 group d.Desc by d.PID into pg
                 select new Result
                 { 
                     Id = pg.Key,  
                     Sum = pg.Sum()
                 };

    return result;
}

然后在您的MainWindow方法中,您将调用此方法。

public MainWindow()
{
    InitializeComponent();
    datagrid.ItemsSource = GetResults();
}

我有supposed你在同一个类中定义了这个方法。这很可能不是一个好习惯。因此,如果您在另一个类中定义此方法,则必须先创建此类的对象,然后再调用此对象的GetResults方法。

此外,我试图在命名方面稍作改动。使用驼峰案例命名更常见,并且不对所有字母使用大写字母。话虽如此,您还需要对xaml代码进行细微更改。

<DataGrid Name="datagrid" AutoGenerateColumns="False" IsReadOnly="True">
    <DataGrid.Columns>
        <DataGridTextColumn Header="id" Binding="{Binding Id}" Width="*"/>
        <DataGridTextColumn Header="Name" Binding="{Binding Sum}" Width="*"/>
    </DataGrid.Columns>
</DataGrid>