我有一个列表存储在resultlist如下:

var resultlist = results.ToList();

它看起来是这样的:

ID FirstName  LastName
-- ---------  --------
1  Bill       Smith
2  John       Wilson
3  Doug       Berg

我如何从列表中删除ID 2 ?


当前回答

简短的回答: 删除(从列表结果中)

结果。RemoveAll(r => r. id == 2);将在results (in place)中删除ID为2的项目。

过滤(不从原始列表结果中删除):

Var filtered = result。Where(f => f.ID != 2);返回除ID为2外的所有项

详细的回答:

我认为. removeall()是非常灵活的,因为你可以有一个你想要删除的项目id列表-请参考下面的例子。

如果你有:

class myClass {
    public int ID; public string FirstName; public string LastName;
}

并为结果赋值如下(用于下面的所有示例):

var results = new List<myClass> {
    new myClass { ID=1, FirstName="Bill", LastName="Smith" },   // results[0]
    new myClass { ID=2, FirstName="John", LastName="Wilson" },  // results[1]
    new myClass { ID=3, FirstName="Doug", LastName="Berg" },    // results[2]
    new myClass { ID=4, FirstName="Bill", LastName="Wilson" }   // results[3]
};

然后你可以定义一个要删除的id列表:

var removeList = new List<int>() { 2, 3 };

然后简单地用这个来移除它们:

results.RemoveAll(r => removeList.Any(a => a==r.ID));

它将删除项目2和3,并保留项目1和4 -由removeList指定。请注意,这发生在适当的位置,因此不需要额外的赋值。

当然,你也可以用在单品上,比如:

results.RemoveAll(r => r.ID==4);

在我们的例子中,它将删除ID为4的Bill。

最后要提到的是列表有一个索引器,也就是说,它们也可以像动态数组一样访问,即results[3]将给你结果列表中的第4个元素(因为第一个元素的索引为0,第二个元素的索引为1等)。

因此,如果你想删除所有第一个名字与结果列表的第4个元素相同的条目,你可以简单地这样做:

results.RemoveAll(r => results[3].FirstName == r.FirstName);

注意,之后,列表中只保留John和Doug, Bill将被删除(示例中的第一个和最后一个元素)。重要的是,列表将自动收缩,因此它只剩下2个元素——因此在本例中执行RemoveAll后允许的最大索引为1(即results.Count() - 1)。

一些琐事:您可以使用这些知识创建一个本地函数

void myRemove()  { var last = results.Count() - 1; 
                   results.RemoveAll(r => results[last].FirstName == r.FirstName); }

如果你调用这个函数两次,你认为会发生什么? 就像

myRemove(); myRemove(); 

答案(点击显示):

第一次呼叫将在第一个和最后一个位置删除比尔,第二次呼叫将删除道格,名单中只剩下约翰·威尔逊。


注意:从c#版本8开始,你也可以写results[^1]而不是var last = results. count () - 1;和结果(最后一个):

void myRemove()  =>  results.RemoveAll(r => results[^1].FirstName == r.FirstName); 

因此,您将不再需要局部变量last(请参阅索引和范围)。此外,由于它是一行程序,所以不需要花括号,可以使用=>代替。 有关c#中所有新特性的列表,请查看这里。


DotNetFiddle:运行演示

其他回答

你没有指定哪种类型的列表,但是通用列表可以使用RemoveAt(index)方法,也可以使用Remove(obj)方法:

// Remove(obj)
var item = resultList.Single(x => x.Id == 2);
resultList.Remove(item);

// RemoveAt(index)
resultList.RemoveAt(1);
resultList = results.Where(x=>x.Id != 2).ToList();

有一个我喜欢的Linq小助手,它很容易实现,可以让带有“where not”条件的查询更容易阅读:

public static IEnumerable<T> ExceptWhere<T>(this IEnumerable<T> source, Predicate<T> predicate)
{
    return source.Where(x=>!predicate(x));
}

//usage in above situation
resultList = results.ExceptWhere(x=>x.Id == 2).ToList();
{
    class Program
    {
        public static List<Product> list;
        static void Main(string[] args)
        {

            list = new List<Product>() { new Product() { ProductId=1, Name="Nike 12N0",Brand="Nike",Price=12000,Quantity=50},
                 new Product() { ProductId =2, Name = "Puma 560K", Brand = "Puma", Price = 120000, Quantity = 55 },
                 new Product() { ProductId=3, Name="WoodLand V2",Brand="WoodLand",Price=21020,Quantity=25},
                 new Product() { ProductId=4, Name="Adidas S52",Brand="Adidas",Price=20000,Quantity=35},
                 new Product() { ProductId=5, Name="Rebook SPEED2O",Brand="Rebook",Price=1200,Quantity=15}};


            Console.WriteLine("Enter ProductID to remove");
            int uno = Convert.ToInt32(Console.ReadLine());
            var itemToRemove = list.Find(r => r.ProductId == uno);
            if (itemToRemove != null)
                list.Remove(itemToRemove);
            Console.WriteLine($"{itemToRemove.ProductId}{itemToRemove.Name}{itemToRemove.Brand}{itemToRemove.Price}{ itemToRemove.Quantity}");
            Console.WriteLine("------------sucessfully Removed---------------");

            var query2 = from x in list select x;
            foreach (var item in query2)
            {
                /*Console.WriteLine(item.ProductId+" "+item.Name+" "+item.Brand+" "+item.Price+" "+item.Quantity );*/
                Console.WriteLine($"{item.ProductId}{item.Name}{item.Brand}{item.Price}{ item.Quantity}");
            }

        }

    }
}

简短的回答: 删除(从列表结果中)

结果。RemoveAll(r => r. id == 2);将在results (in place)中删除ID为2的项目。

过滤(不从原始列表结果中删除):

Var filtered = result。Where(f => f.ID != 2);返回除ID为2外的所有项

详细的回答:

我认为. removeall()是非常灵活的,因为你可以有一个你想要删除的项目id列表-请参考下面的例子。

如果你有:

class myClass {
    public int ID; public string FirstName; public string LastName;
}

并为结果赋值如下(用于下面的所有示例):

var results = new List<myClass> {
    new myClass { ID=1, FirstName="Bill", LastName="Smith" },   // results[0]
    new myClass { ID=2, FirstName="John", LastName="Wilson" },  // results[1]
    new myClass { ID=3, FirstName="Doug", LastName="Berg" },    // results[2]
    new myClass { ID=4, FirstName="Bill", LastName="Wilson" }   // results[3]
};

然后你可以定义一个要删除的id列表:

var removeList = new List<int>() { 2, 3 };

然后简单地用这个来移除它们:

results.RemoveAll(r => removeList.Any(a => a==r.ID));

它将删除项目2和3,并保留项目1和4 -由removeList指定。请注意,这发生在适当的位置,因此不需要额外的赋值。

当然,你也可以用在单品上,比如:

results.RemoveAll(r => r.ID==4);

在我们的例子中,它将删除ID为4的Bill。

最后要提到的是列表有一个索引器,也就是说,它们也可以像动态数组一样访问,即results[3]将给你结果列表中的第4个元素(因为第一个元素的索引为0,第二个元素的索引为1等)。

因此,如果你想删除所有第一个名字与结果列表的第4个元素相同的条目,你可以简单地这样做:

results.RemoveAll(r => results[3].FirstName == r.FirstName);

注意,之后,列表中只保留John和Doug, Bill将被删除(示例中的第一个和最后一个元素)。重要的是,列表将自动收缩,因此它只剩下2个元素——因此在本例中执行RemoveAll后允许的最大索引为1(即results.Count() - 1)。

一些琐事:您可以使用这些知识创建一个本地函数

void myRemove()  { var last = results.Count() - 1; 
                   results.RemoveAll(r => results[last].FirstName == r.FirstName); }

如果你调用这个函数两次,你认为会发生什么? 就像

myRemove(); myRemove(); 

答案(点击显示):

第一次呼叫将在第一个和最后一个位置删除比尔,第二次呼叫将删除道格,名单中只剩下约翰·威尔逊。


注意:从c#版本8开始,你也可以写results[^1]而不是var last = results. count () - 1;和结果(最后一个):

void myRemove()  =>  results.RemoveAll(r => results[^1].FirstName == r.FirstName); 

因此,您将不再需要局部变量last(请参阅索引和范围)。此外,由于它是一行程序,所以不需要花括号,可以使用=>代替。 有关c#中所有新特性的列表,请查看这里。


DotNetFiddle:运行演示

更多的简化:

resultList.Remove(resultList.Single(x => x.Id == 2));

不需要创建一个新的var对象。