CollectionViewSource分组,获取总和(数量)

时间:2019-01-25 06:35:21

标签: c# wpf collectionviewsource

我有一个CollectionViewSource,其来源是ObservableCollection。

ListObservableCollection上,我可以使用linq对对象进行分组,并对它们的数量求和,但是如何在CollectionViewSource上做到这一点(如果可能),我在任何地方都看不到任何文档。

目前,我只能使用来管理分组:

ProductsView.GroupDescriptions.Add(new PropertyGroupDescription("Group"));

但是我看不到任何信息如何显示字段的总和或最大值/最小值?

编辑:

具体来说,我想做些等效的事情:

liste_ass = liste_ass.GroupBy(l => l.Name)
     .Select(cl => new Assemblage
     {
         Quantite = cl.Sum(c => c.Quantite),
         ID = 0,
         IdAffaire = cl.First().IdAffaire,
         Name = cl.First().Name,
         Priorite = 0,
         Dessin = cl.First().Dessin,
         Groupe = cl.First().Groupe,
         Priorite = cl.Max(c=>c.Priorite),
         ListeIdOperations = cl.First().ListeIdOperations,
     }).ToList();

这就是我在linq中要做的。 但是,在阅读有关ICollectionView的内容后,似乎无法在ICollectionView上执行此操作,因为它是一个视图,并且无法对其进行任何操作。

2 个答案:

答案 0 :(得分:1)

您可以访问每个CollectionViewGroupItemCount属性,其中包含所有古尔普信息,包括CollectionView.Groups。如果要创建自定义组标题并将其显示在UI上,请参考以下示例:

    <ListBox ItemsSource="{Binding your view}">
         <ListBox.Resources>
             <local:ToAssemblageConverter x:Key="toAssemblageConverter"/>
         </ListBox.Resources>
         <ListBox.GroupStyle>
            <GroupStyle HidesIfEmpty="True">
                <GroupStyle.HeaderTemplate>
                    <DataTemplate>
                        <StackPanel Orientation="Horizontal"
                                    DataContext="{Binding Items, Converter={StaticResource ResourceKey=toAssemblageConverter}}">
                            <TextBlock Margin="5 0" Text="{Binding Quantite}"/>
                            <TextBlock Margin="5 0" Text="{Binding Id}"/>
                            ...
                        </StackPanel>     
                    </DataTemplate>
                </GroupStyle.HeaderTemplate>
            </GroupStyle>
        </ListBox.GroupStyle>           
    </ListBox>

public class ToAssemblageConverter : IValueConverter
{
    public object Convert (object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
    {
        var cl = (IEnumerable)value;

        return new Assemblage() {
            Quantite = cl.Sum(c => c.Quantite),
            ID = 0,
            IdAffaire = cl.First().IdAffaire,
            Name = cl.First().Name,
            Priorite = 0,
            Dessin = cl.First().Dessin,
            Groupe = cl.First().Groupe,
            Priorite = cl.Max(c=>c.Priorite),
            ListeIdOperations = cl.First().ListeIdOperations,
        }
    }
}

答案 1 :(得分:1)

您可以使用DynamicData

var sourceList = new SourceList<YourType>(); // use this instead of ObservableCollection

sourceList.Connect()
     .AutoRefres(x => x.Quantite) // refresh when this property changes
     .ToCollection()
     .Select(col => 
                col
            .GroupBy(l => l.Name)
            .Select(cl => new Assemblage
            {
                Quantite = cl.Sum(c => c.Quantite),
                ID = 0,
                IdAffaire = cl.First().IdAffaire,
                Name = cl.First().Name,
                Priorite = 0,
                Dessin = cl.First().Dessin,
                Groupe = cl.First().Groupe,
                Priorite = cl.Max(c=>c.Priorite),
                ListeIdOperations = cl.First().ListeIdOperations,
            }).ToList()
            )
       .Subscribe(col => PublicPropertyWithChangeNotification = col);

当您在源列表中添加或删除项目时,item.Quantite发生更改(如果它实现了INPC),它将自动更新结果