筛选后的 ICollectionView 的总和
sum of filtered ICollectionView
假设这个基数class
public class Contrat_Paye_Item
{
public int CPI_TYPE { get; set; }
public string CPI_TEXT { get; set; }
public decimal CPI_AMOUNT { get; set; }
}
在我看来,我已经从 class 中列出了一个列表,如下所示:
private ObservableCollection<Contrat_Paye_Item> listapayer;
public ObservableCollection<Contrat_Paye_Item> ListaPayer
{
get
{
return listapayer;
}
set
{
listapayer = value;
OnPropertyChanged("ListaPayer");
}
}
并且在 VM 构造函数中,只是一些测试数据:
listapayer.Add(new Contrat_Paye_Item()
{
CPI_TYPE = 0,
CPI_TEXT = "Loyer",
CPI_AMOUNT = 100
});
listapayer.Add(new Contrat_Paye_Item()
{
CPI_TYPE = 1,
CPI_TEXT = "charge 1",
CPI_AMOUNT = 200
});
listapayer.Add(new Contrat_Paye_Item()
{
CPI_TYPE = 1,
CPI_TEXT = "Charges 2",
CPI_AMOUNT = 300
});
因此完整列表包含 3 个项目,总金额为 600。
在我的视图模型中,我添加了一个仅包含 CPI_TYPE = 1 项的子列表,并将其绑定到一个列表框,没有这样的问题:
public ICollectionView ListCharges
{
get
{
var sub= new CollectionViewSource { Source = listapayer }.View;
sub.Filter = p => (p as Contrat_Paye_Item).CPI_TYPE == 1;
return sub;
}
}
现在我要显示的是我的项目列表,其中一行包含子列表的 总金额 项目。将它绑定到第二个列表框
类似于:
忠诚者 100
收费500
任何想法,欢迎提示。
谢谢
在返回子之前添加这样的东西如何:
var d1 = (from a in sub.SourceCollection.OfType<Contrat_Paye_Item>() where a.CPI_TEXT == "Loyer" select a.CPI_AMOUNT).Sum();
var d2 = (from a in sub.SourceCollection.OfType<Contrat_Paye_Item>() where a.CPI_TEXT.ToLower().StartsWith("charge") select a.CPI_AMOUNT).Sum();
sub.AddNewItem(new Contrat_Paye_Item() { CPI_TEXT="Sum Loyer", CPI_AMOUNT = d1} );
sub.CommitNew();
sub.AddNewItem(new Contrat_Paye_Item() { CPI_TEXT = "Sum Charges", CPI_AMOUNT = d2 });
sub.CommitNew();
//编辑
注意这是一种更灵活的可能性:
不要使用 _CollectionViewSource _。而是将以下内容用作 ListBox 的 ItemsSource:
public ObservableCollection<Contrat_Paye_Item> ListCharges
{
get
{
return new ObservableCollection<Contrat_Paye_Item>((from a in listapayer where a.CPI_TYPE == 1 select a));
}
}
假设这个基数class
public class Contrat_Paye_Item
{
public int CPI_TYPE { get; set; }
public string CPI_TEXT { get; set; }
public decimal CPI_AMOUNT { get; set; }
}
在我看来,我已经从 class 中列出了一个列表,如下所示:
private ObservableCollection<Contrat_Paye_Item> listapayer;
public ObservableCollection<Contrat_Paye_Item> ListaPayer
{
get
{
return listapayer;
}
set
{
listapayer = value;
OnPropertyChanged("ListaPayer");
}
}
并且在 VM 构造函数中,只是一些测试数据:
listapayer.Add(new Contrat_Paye_Item()
{
CPI_TYPE = 0,
CPI_TEXT = "Loyer",
CPI_AMOUNT = 100
});
listapayer.Add(new Contrat_Paye_Item()
{
CPI_TYPE = 1,
CPI_TEXT = "charge 1",
CPI_AMOUNT = 200
});
listapayer.Add(new Contrat_Paye_Item()
{
CPI_TYPE = 1,
CPI_TEXT = "Charges 2",
CPI_AMOUNT = 300
});
因此完整列表包含 3 个项目,总金额为 600。
在我的视图模型中,我添加了一个仅包含 CPI_TYPE = 1 项的子列表,并将其绑定到一个列表框,没有这样的问题:
public ICollectionView ListCharges
{
get
{
var sub= new CollectionViewSource { Source = listapayer }.View;
sub.Filter = p => (p as Contrat_Paye_Item).CPI_TYPE == 1;
return sub;
}
}
现在我要显示的是我的项目列表,其中一行包含子列表的 总金额 项目。将它绑定到第二个列表框
类似于:
忠诚者 100
收费500
任何想法,欢迎提示。 谢谢
在返回子之前添加这样的东西如何:
var d1 = (from a in sub.SourceCollection.OfType<Contrat_Paye_Item>() where a.CPI_TEXT == "Loyer" select a.CPI_AMOUNT).Sum();
var d2 = (from a in sub.SourceCollection.OfType<Contrat_Paye_Item>() where a.CPI_TEXT.ToLower().StartsWith("charge") select a.CPI_AMOUNT).Sum();
sub.AddNewItem(new Contrat_Paye_Item() { CPI_TEXT="Sum Loyer", CPI_AMOUNT = d1} );
sub.CommitNew();
sub.AddNewItem(new Contrat_Paye_Item() { CPI_TEXT = "Sum Charges", CPI_AMOUNT = d2 });
sub.CommitNew();
//编辑
注意这是一种更灵活的可能性:
不要使用 _CollectionViewSource _。而是将以下内容用作 ListBox 的 ItemsSource:
public ObservableCollection<Contrat_Paye_Item> ListCharges
{
get
{
return new ObservableCollection<Contrat_Paye_Item>((from a in listapayer where a.CPI_TYPE == 1 select a));
}
}