是否可以在。net中使用c#将两个或多个列表转换为一个列表?

例如,

public static List<Product> GetAllProducts(int categoryId){ .... }
.
.
.
var productCollection1 = GetAllProducts(CategoryId1);
var productCollection2 = GetAllProducts(CategoryId2);
var productCollection3 = GetAllProducts(CategoryId3);

当前回答

我知道这是一个老问题,我想我可能只是说说我的意见。

如果你有一个List<Something>[],你可以使用聚合来连接它们

public List<TType> Concat<TType>(params List<TType>[] lists)
{
    var result = lists.Aggregate(new List<TType>(), (x, y) => x.Concat(y).ToList());

    return result;
}

希望这能有所帮助。

其他回答

假设您想要一个包含指定类别id的所有产品的列表,您可以将查询视为一个投影,然后是一个扁平化操作。有一个LINQ操作符做这个:SelectMany。

// implicitly List<Product>
var products = new[] { CategoryId1, CategoryId2, CategoryId3 }
                     .SelectMany(id => GetAllProducts(id))
                     .ToList();

在c# 4中,你可以将SelectMany缩短为:.SelectMany(GetAllProducts)

如果您已经拥有代表每个Id的产品的列表,那么正如其他人指出的那样,您需要的是一个连接。

列表。AddRange将通过添加额外的元素来改变(突变)一个现有的列表:

list1.AddRange(list2); // list1 now also has list2's items appended to it.

或者,在现代的不可变风格中,你可以在不改变现有列表的情况下投影出一个新的列表:

Concat,它表示list1的项的无序序列,后面跟着list2的项:

var concatenated = list1.Concat(list2).ToList();

不太一样的是,Union投射了一个截然不同的项目序列:

var distinct = list1.Union(list2).ToList();

注意,为了让Union的“值类型不同”行为在引用类型上工作,你需要为你的类定义相等比较(或者使用记录类型的内置比较器)。

你可以使用LINQ将它们组合起来:

  list = list1.Concat(list2).Concat(list3).ToList();

使用List.AddRange()这种更传统的方法可能更有效。

list4 = list1.Concat(list2).Concat(list3).ToList();

您需要使用Concat操作