假设我有这样的LINQ查询:

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

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

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

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


当前回答

简单的解决方案:

static void Main()
{
    List<string> myList = new List<string> { "Jason", "Bob", "Frank", "Bob" };
    myList.RemoveAll(x => x == "Bob");

    foreach (string s in myList)
    {
        //
    }
}

其他回答

我觉得你可以这样做

    authorsList = (from a in authorsList
                  where !authors.Contains(a)
                  select a).ToList();

尽管我认为已经给出的解决方案以更易于阅读的方式解决了问题。

使用标准LINQ操作符无法做到这一点,因为LINQ提供的是查询,而不是更新支持。

但是您可以生成一个新的列表并替换旧的列表。

var authorsList = GetAuthorList();

authorsList = authorsList.Where(a => a.FirstName != "Bob").ToList();

或者您可以在第二次操作中删除authors中的所有项。

var authorsList = GetAuthorList();

var authors = authorsList.Where(a => a.FirstName == "Bob").ToList();

foreach (var author in authors)
{
    authorList.Remove(author);
}

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

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

为了保持代码流畅(如果代码优化不是关键),你需要对列表做一些进一步的操作:

authorsList = authorsList.Where(x => x.FirstName != "Bob").<do_some_further_Linq>;

or

authorsList = authorsList.Where(x => !setToRemove.Contains(x)).<do_some_further_Linq>;

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

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

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