[英]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.