我有这段代码:
List<MyObjectOne> myListOne = new List<MyObjectOne>(){new MyObjectOne { ID = 1, field2 = 2}};
List<MyObjectTwo> myListTwo = new List<MyObjectTwo>(){new MyObjectTwo { ID = 4, field6 = "string"}};
bool hasSomething = false;
var result = new[] { new {ID = 0 }}.ToList();
if (hasSomething)
{
// Use list one.
result = myListOne.Select(x => new { ID = x.ID});
}
else
{
// Use list two.
result = myListTwo.Select(x => new { ID = x.ID });
}
foreach (var item in result)
{
// Some logic to manipulate item.ID.
item.ID;
}
我尝试做的是使用相同的匿名类型从两个不同的列表中选择ID列表。因此,我使用Select(x => new { ID = x.ID })
为每个表创建匿名类型,以便只有一个for循环。
引发的错误是“无法将类型IEnumerable隐式转换为List ”
¿任何想法?
答案 0 :(得分:3)
假设ID
中的MyObjectOne
和MyObjectTwo
int
都是var result = new[] { new { ID = 0 } }.AsEnumerable();
,如果您将ToList
替换为{{3},您的代码将会有效}}:
ID
如果long
属性属于其他类型(例如var result = new[] { new { ID = 0L } }.AsEnumerable();
&#39; s),则需要在此处创建匿名类型时指定:
var result = new[] { new { ID = (long)0 } }.AsEnumerable();
或者像这样:
var result = hasSomething
? myListOne.Select(x => new { ID = x.ID })
: myListTwo.Select(x => new { ID = x.ID });
然而,这种代码有点令人困惑,我不建议将其用于生产环境。这是一个替代解决方案,可以避免创建一个虚拟的&#39;对象仅用于隐式匿名输入:
{{1}}