我有2个类Feed_Auto和具有多个匹配属性的Product.对于这个特殊问题,AutoID是我需要使用的唯一字段.
我有一个List< FeedsAuto>有几百个独特的条目.我有一个小的列表<产品>有10个,20个独特的条目.我现在想要从大列表中删除小列表中的所有项目.
如何使用RemoveAll({lambda expression})来完成此任务?我发现的所有示例都取决于通用列表是简单类型(字符串,整数等).
- private static int DoInserts(ref List<Model.Feeds_Auto> source,ref List<Model.Product> target,Guid companyID)
- {
- List<Model.Product> newProductList = new List<Model.Product>();
- List<Model.Product> dropSourceList = new List<Model.Product>();
- using (var db = Helpers.GetProdDB())
- {
- foreach (var src in source)
- {
- var tgt = target.Where(a => a.alternateProductID == src.AutoID && a.LastFeedUpdate < src.DateModified).FirstOrDefault();
- if (tgt == null)
- {
- newProductList.Add(new Model.Product{...});
- dropSourceList.Add(src);
- }
- }
- db.SaveChanges();
- if (dropSourceList.Count > 0)
- {
- source.RemoveAll(????);
- }
- }
- }
要在循环中执行此操作并不困难:
- foreach (var drop in dropSourceList)
- {
- source.RemoveAll(a => a.AutoID == drop.AutoID);
- }
对于我来说,循环一个集合来为每个传递中的一个项目调用RemoveAll是没有意义的.
解决方法
您可以使用Any来简化
- source.RemoveAll(a => dropSourceList.Any(b => a.AutoID == b.AutoID));
您可以通过首先创建ID的HashSet来减少循环:
- var toRemove = new HashSet<int>(dropSourceList.ConvertAll(a => a.AutoID));
- source.RemoveAll(a => toRemove.Contains(a.AutoID));