我正在尝试调用嵌套列表操作。我有两个不同的列表,但Name是它们的公共变量。我有两个列表,这是我正在尝试的:
selectedImage
public int Id { get; set; }
public int X { get; set; }
public int Y { get; set; }
public string Name { get; set; }
generatedEyeDistance
public string Name { get; set; }
public double eyeDistance { get; set; }
我想调用generetedEyeDistance的eyeDistance值,但Name应该相同。我试过了:
var asdasf = generatedEyeDistance.Where(f=> (f.Name) == (selectedImage.Select(name => name.Name))).ToList();
但这会产生以下错误:
Operator '==' cannot be applied to operands of type 'string' and 'System.Collections.Generic.IEnumerable<string>'
而且我的做法看起来也错了。任何人都可以帮我解决这个问题吗?
答案 0 :(得分:7)
如果您想获得所选图像的生成距离,请在名称上加入两个集合:
from d in generatedEyeDistance
join i in selectedImage
on d.Name equals i.Name
select d
Lambda语法(我不喜欢连接,但是..)
generatedEyeDistance.Join(selectedImage, d => d.Name, i => i.Name, (d,i) => d)
BTW你有问题,因为selectedImage.Select(name => name.Name)
返回名称序列,并且你试图将序列与距离名称进行比较。实际上你要检查是否存在与距离名称相同的图像:
generatedEyeDistance.Where(d => selectedImage.Any(i => i.Name == d.Name))
但是join更有效率,因为它使用set而不是为每个距离进行子查询。
更新:还有一个选项,如果您有距离列表,并且不想使用查询语法 - 那么您可以手动创建名称集并过滤距离列表:
var names = new HashSet<string>(selectedImage.Select(i => i.Name));
var result = generatedEyeDistance.FindAll(d => names.Contains(d.Name));