我有一个列表存储在resultlist如下:
var resultlist = results.ToList();
它看起来是这样的:
ID FirstName LastName
-- --------- --------
1 Bill Smith
2 John Wilson
3 Doug Berg
我如何从列表中删除ID 2 ?
我有一个列表存储在resultlist如下:
var resultlist = results.ToList();
它看起来是这样的:
ID FirstName LastName
-- --------- --------
1 Bill Smith
2 John Wilson
3 Doug Berg
我如何从列表中删除ID 2 ?
当前回答
List<T>有两个方法可以使用。
如果知道项的索引,可以使用RemoveAt(int index)。例如:
resultlist.RemoveAt(1);
或者你可以使用Remove(T项):
var itemToRemove = resultlist.Single(r => r.Id == 2);
resultList.Remove(itemToRemove);
当你不确定项目是否存在时,你可以使用SingleOrDefault。如果没有项目,SingleOrDefault将返回null(当Single找不到项目时将抛出异常)。当存在重复值(两个具有相同id的项)时,两者都会抛出。
var itemToRemove = resultlist.SingleOrDefault(r => r.Id == 2);
if (itemToRemove != null)
resultList.Remove(itemToRemove);
其他回答
还有另一种方法。它使用List。FindIndex和List.RemoveAt。
虽然我可能会使用KeithS提供的解决方案(只是简单的Where/ToList),但这种方法的不同之处在于它改变了原始的列表对象。这可能是好事(也可能是坏事)“特性”取决于期望。
在任何情况下,FindIndex(加上一个保护)确保RemoveAt在id中有空白或顺序错误等情况下是正确的,并且使用RemoveAt (vs Remove)避免了在列表中进行第二次O(n)搜索。
以下是LINQPad代码片段:
var list = new List<int> { 1, 3, 2 };
var index = list.FindIndex(i => i == 2); // like Where/Single
if (index >= 0) { // ensure item found
list.RemoveAt(index);
}
list.Dump(); // results -> 1, 3
快乐的编码。
你没有指定哪种类型的列表,但是通用列表可以使用RemoveAt(index)方法,也可以使用Remove(obj)方法:
// Remove(obj)
var item = resultList.Single(x => x.Id == 2);
resultList.Remove(item);
// RemoveAt(index)
resultList.RemoveAt(1);
简短的回答: 删除(从列表结果中)
结果。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对象。
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();