【问题标题】:Foreach loop and lambda expressionsForeach 循环和 lambda 表达式
【发布时间】:2016-11-07 18:21:33
【问题描述】:

我有以下模型类:

public class Promotion
{
     public Offers Offers { get; set; }    
}
public class Offers
{
    public List<PromotionOffer> Offer { get; set; }
}
public class PromotionOffer
{
    public string CategoryName { get; set; }
    public List<Product> Product { get; set; }
}

public class Product
{
    public string ProductName { get; set; }
}

我有Promotion 对象和一个字符串allProducts

Promotion promotion = promotion;
string allProducts = string.Empty;

我想在 CategoryName == "Premium" 的所有产品中分配和附加 ProductName。 是否可以使用 lambda 表达式来实现这一点?或者也需要一个foreach循环?请指导,我怎样才能做到这一点?

【问题讨论】:

  • 您是说要更改现有ProductName 属性的值吗?或者您是说要将它们全部附加到allProducts?还是两者兼而有之?

标签: c# foreach lambda


【解决方案1】:
promotion.Offers
         .Offer
         .Where(o => o.CategoryName == "Premium")
         .SelectMany(o => o.Product)
         .ToList()
         .ForEach(n => n.ProductName = n.ProductName + "AppendedString");

如果您想在没有foreach 循环的情况下将其淘汰,您可以使用ListForEach 方法以及LINQ


如果您实际上只想构建这些产品名称的字符串,您可以使用:

var strs = promotion.Offers
                    .Offer
                    .Where(o => o.CategoryName == "Premium")
                    .SelectMany(o => o.Product)
                    .Select(p => p.ProductName); 

var allProducts = string.Join(",", strs);

【讨论】:

    【解决方案2】:

    可以通过System.LinqString.Join实现:

    public static string ProductNameList(Promotion promotion, string category) {
        var products = promotion.Offers
            .Where(x => x.CategoryName == category)
            .SelectMany(x => x.Product)
            .Select(x => x.ProductName);
        return String.Join(", ", products);
    }}
    

    【讨论】:

    • 好答案,唯一的问题是 promotion.Offers.Where 它应该是 promotion.Offers.Offer.Where
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-02-14
    • 2021-12-07
    • 1970-01-01
    相关资源
    最近更新 更多