过滤列表并删除不需要的数据C#

鲁本·雷德曼(Ruben Redman)

我有个list的用户timespan,出于参数考虑,我们假设一个月。因此,由于list某些用户不符合我为某个目标所要满足的条件,因此我要过滤掉,list并将过滤出的数据显示到另一个对象中list因此,我的复制list方式如下:

List<tblList1> List1 = new XPQuery<tblList1>(session)
    .Where(w => w.UserCode != null).ToList();

然后,我使用foreach循环遍历此列表以将数据与我的条件进行比较,然后将它们添加到运行良好的新列表中。我现在遇到的问题是删除我从第一个获取的数据list我在自己创建的新方法中尝试了以下方法:

public void DeleteData(Session session)
{
    List<tblList1> List1= new XPQuery<tblList1>(session)
        .Where(w => w.UserID != null).ToList();

    List<tblList2> List2= new XPQuery<tblList2>(session)
        .Where(w => w.UserID!= null).ToList();

    List1.RemoveAll(w => w.UserID == List2.Any(e => e.UserID== w.UserID));
}

因此,最后我想删除list1中的所有数据,以便我们可以查看list2中已删除的数据。如果我能使正确的RemoveAll LINQ语句正确,因为当前行不起作用,并且不确定如何在LINQ中处理此问题,将对您有所帮助。

耶尔达·库曼加利耶夫(Yeldar Kurmangaliyev)

您可以只使用LINQWhere来过滤列表,然后Except获取未过滤的值:

List<Item> all = ...; // your original list
List<Item> matching = all.Where(x => IsMatching(x)).ToList(); // IsMatching is any filtering logic
List<Item> notMatching = all.Except(matching).ToList();

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章