在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上做的那样?
谢谢!
答案 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>