我有两个列表,都有一个ID(唯一的),我想要做的就是通过它的唯一属性对它们进行分组,并得到一个包含两个列表的新列表。
list1 group by list2 -> get list3
这是我的代码:
List<LeadDocumentStatusQuerySequence> list1 =
client.GetLeadDocumentStatusQuerySequence();
List<LeadDocumentStatusQueryDeclarationDetails> list2 =
client.GetLeadDocumentStatusQueryDeclarationDetails();
我需要获得包含两个列表的第三个列表,我想按ID分组,但是如何在LINQ中编写它?
var both = ...?
提前致谢。
答案 0 :(得分:3)
我不确定这是否是您想要的,但请参阅下文。我假设People是Animal的子类。
var combinedList = new List<Animal>();
combinedList.AddRange(people);
combinedList.AddRange(animals);
var grouped = combinedList.GroupBy(y => new {y.ID}).ToList();
答案 1 :(得分:1)
目前尚不清楚如何操纵数据,但使用CompositeCollection可以将数据分组在一起。它在WPF中用于组合要在屏幕上显示的不同集合。
请注意,以下类中的Name
在C#编译器意义上并不直接相关,因此两者之间没有直接关联:
void Main()
{
var myAnimals = new List<Animal>() { new Animal() { Name = "Zebra" },
new Animal() { Name = "Cobra" }} ;
var myPeople = new List<Person>() { new Person() { Name = "Snake Pliskin" },
new Person() { Name = "OmegaMan" }};
// Uses System.Windows.Data
var FavoriteThings = new CompositeCollection();
FavoriteThings.Add(myAnimals);
FavoriteThings.Add(myPeople);
}
// Define other methods and classes here
public class Animal
{
public string Name { get; set; }
}
public class Person
{
public string Name { get; set; }
}