我有一个简单的患者类,有类似的属性
public int PatientId { get; set; }
public string FirstName { get; set; }
public string LastName { get; set; }
Run Code Online (Sandbox Code Playgroud)
以及基于他们的PatientId返回随机患者的功能
public static Patient GetRandomPatient(IEnumerable<Patient> patList)
{
Random r = new Random();
int patientValue = r.Next(patList.Min().PatientId, patList.Max().PatientId);
//return from g in patList
// where g.PatientId == patientValue
// select g;
var test = from g in patList
where g.PatientId == patientValue
select g;
return (Patient)test;
}
Run Code Online (Sandbox Code Playgroud)
注释掉的行是第一次尝试返回由Random类选择PatientId的患者.那没有编译,我得到了错误
Cannot implicitly convert type... (are you missing a cast)?
所以然后我运行了没有注释掉的迭代并得到了异常
At least one object must implement IComparable.
所以我尝试了这个作为我的回复声明
Patient testPatient = patList.First(x => x.PatientId == patientValue);
return testPatient;
Run Code Online (Sandbox Code Playgroud)
这编译没有错误,但是当我运行它时,我得到一个对象必须实现IComparable的相同异常.
我想知道两件事1.在使用LINQ语法从列表中返回单个对象时,我似乎没有达到这个概念(在这种情况下,每个PatientId都是唯一的,因此return语句可以只能返回一个Patient对象)?2.为什么代码
Patient testPatient = patList.First(x => x.PatientId == patientValue);
return testPatient;
Run Code Online (Sandbox Code Playgroud)
编译并且没有编译器错误,但是其他迭代具有相同异常的炸弹?
主功能
List<Patient> patientList = new List<Patient>();
patientList.Add(new Patient() { PatientId = 101, FirstName = "John", LastName = "Jacosdfasdfasdfb" });
patientList.Add(new Patient() { PatientId = 100, FirstName = "Mary", LastName = "Wilson" });
patientList.Add(new Patient() { PatientId=102, FirstName="Max",LastName="Payne"});
//Call that bombs the program Console.WriteLine(Patient.GetRandomPatient(patientList).PatientId);
Run Code Online (Sandbox Code Playgroud)
由于错误试图告诉你,你.Min()和.Max()电话没有意义.
您只能调用Min()或Max()可以与彼此进行比较的对象集合.
相反,您需要在ID集合上调用它们:
patients.Select(p => p.PatientId).Min()
Run Code Online (Sandbox Code Playgroud)
您也可以用更简单(更快)的方式替换整个功能
return patients.ElementAt(rand.Next(patients.Count()));
Run Code Online (Sandbox Code Playgroud)