从集合对象中删除/跳过项目的最佳方法是什么
List<Person> personList = new List<Person>()
personList = dao.GetData(123);
personList = personList.Select(x => x.Comment... ????
结果集:
"GCE"
Not available
"" //comments
"RES"
9.97000000
9.99000000
........
........
........
所以,我的目标是“评论”字段,如果评论为空,则不要渲染。
我可以在foreach
循环中使用if condition
进行此操作,但我正在寻找最佳做法
答案 0 :(得分:9)
如果您想破坏性地从列表中删除违规项,请使用RemoveAll(Predicate<T>)
方法;它删除与列表中的谓词匹配的每个项目:
myList.RemoveAll(x=>x.Comment == whatever);
如果您希望保持列表相同并制作过滤序列项目,请使用Where
:
foreach(Item item in myList.Where(x=>x.Comment != whatever))
...
这使列表保持不变; Where
只会为您提供已应用过滤器的列表的“视图”。
答案 1 :(得分:6)
您可以使用Where
之类的...
foreach (var a in personList.where(x => !string.IsNullOrWhitespace(x.Comment))
{
// code
}
答案 2 :(得分:1)
这会将列表限制为具有非空和非空白字符串的注释:
List<Person> personList = dao.GetData(123);
filteredList = personList.Where(x => !String.IsNullOrWhitespace(x.Comment));
答案 3 :(得分:1)
您甚至可以在使用之前使用LINQ过滤集合。首先,这是多余的:
List<Person> personList = new List<Person>()
personList = dao.GetData(123);
personList = personList.Select(x => x.Comment... ????
听起来你正在寻找的是:
var personList = dao.GetData(123)
.Where(p => !string.IsNullOrWhitespace(p.Comment))
.Select(p => ...
然后,您可以遍历personList
中的项目。
当然,回过头来看,如果你甚至不需要 .Select()
(也就是说,除了尝试过滤之外没有做任何事情),那么这就更简单了:
var personList = dao.GetData(123)
.Where(p => !string.IsNullOrWhitespace(p.Comment))
答案 4 :(得分:1)
您可以关注两个扩展程序:
Where
:
var subset = collection.Where(x => x != someValue);
此方法只接受所有元素并将谓词应用于它,仅产生匹配元素。
Skip
,SkipWhile
:
var skipFirstThreeItems = collection.Skip(3);
var skippedItems = collection.SkipWhile(x => x != "SomeValue")
与第二个的重要区别在于它将跳过值直到谓词匹配,然后它将采用所有后续元素。
答案 5 :(得分:0)
我经常认为最佳方式值得商榷,但我喜欢显式关于代码正在做什么:
var peopleWithComments = dao.GetData(123)
.Where(person => person.Comment.IsPresent());
...
public static class StringExtensions {
public bool IsPresent(this string self) {
return !String.IsNullOrWhitespace(self);
}
}