假设我有这样的LINQ查询:

var authors = from x in authorsList
              where x.firstname == "Bob"
              select x;

假设authorsList的类型是List<Author>,我如何从authorsList中删除查询返回的Author元素?

或者,换句话说,我如何从authorsList中删除所有与Bob相同的firstname ?

注意:这是一个简化的例子,以方便提问。


当前回答

这是一个非常古老的问题,但我找到了一个非常简单的方法:

authorsList = authorsList.Except(authors).ToList();

注意,由于返回变量authorsList是一个List<T>,所以Except()返回的IEnumerable<T>必须转换为List<T>。

其他回答

最好使用List<T>。RemoveAll来完成这个任务。

authorsList.RemoveAll((x) => x.firstname == "Bob");

这是一个非常古老的问题,但我找到了一个非常简单的方法:

authorsList = authorsList.Except(authors).ToList();

注意,由于返回变量authorsList是一个List<T>,所以Except()返回的IEnumerable<T>必须转换为List<T>。

如果你真的需要删除项目,那么Except()怎么办? 你可以基于一个新的列表删除,或者通过嵌套Linq。

var authorsList = new List<Author>()
{
    new Author{ Firstname = "Bob", Lastname = "Smith" },
    new Author{ Firstname = "Fred", Lastname = "Jones" },
    new Author{ Firstname = "Brian", Lastname = "Brains" },
    new Author{ Firstname = "Billy", Lastname = "TheKid" }
};

var authors = authorsList.Where(a => a.Firstname == "Bob");
authorsList = authorsList.Except(authors).ToList();
authorsList = authorsList.Except(authorsList.Where(a=>a.Firstname=="Billy")).ToList();

我认为你只需要将作者列表中的项目分配到一个新的列表中就可以了。

//assume oldAuthor is the old list
Author newAuthorList = (select x from oldAuthor where x.firstname!="Bob" select x).ToList();
oldAuthor = newAuthorList;
newAuthorList = null;

你可以用两种方法去除

var output = from x in authorsList
             where x.firstname != "Bob"
             select x;

or

var authors = from x in authorsList
              where x.firstname == "Bob"
              select x;

var output = from x in authorsList
             where !authors.Contains(x) 
             select x;

我也有同样的问题,如果你想根据你的where条件简单输出,那么第一个解决方案更好。