![](/img/trans.png)
[英]How can I get totals for more than one column in a list and put this into an object using LINQ?
[英]Using Linq to object, how can I get one field's value based on another in the same list
我有一个定义如下的类:
public class MyClass
{
public int ID { get; set; }
public string Name { get; set; }
}
然后,我有一个逻辑在其中建立该类的列表:
MyList = new List<MyClass>;
foreach(MyClassData myClass in Service.MyClassList)
{
MyList.Add(new MyClass{ID = myClass.ID, Name = myClass.Name});
}
现在,我需要基于“名称”获得一个“ ID”。
我正在尝试以下方法:
int id01 = MyList.Where(x => x.FileName.Equals("File01")).Single(x => x.FileID)
这样做,我收到一条错误消息:
无法将类型'int'隐式转换为'bool'
我将如何使用LINQ做到这一点?
Single
方法是:
public static TSource Single<TSource>( this IEnumerable<TSource> source, Func<TSource, bool> predicate )
它得到一个谓词,该谓词应返回布尔值,但您将返回一个整数。 它用于过滤而不是投影。
您正在寻找的是:
int id01 = MyList.Single(x => x.FileName.Equals("File01")).FileID;
或更好地使用SingleOrDefault
:
int id01 = MyList.SingleOrDefault(x => x.FileName.Equals("File01"))?.FileID;
另请参阅是否要使用SingleOrDefault
或FirstOrDefault
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.