1

以下を実行しましたが、正常に動作しています。

 public StandardReportsModel GetStandardReportsModel(string adUser, string adPassword, IPrincipal user)
 {

    var myItems = getMyItems().Where(myItem => !string.IsNullOrEmpty(myItem.Description));
    var categories = new List<string>();
    var myItems = new List<MyModel>();

    foreach (var myItem in myItems)
    {           
       var myIndex = myItem.Description.IndexOf('*');
       var category = myIndex != -1 ? myItem.Description.Substring(0, myIndex).ToUpper() : myItem.Description.ToUpper();   

       if (categories.IndexOf(category) == -1)
       {
          categories.Add(category);
       }              

       myItems.Add(getMyItem(myItem, category));
    }
    categories.Sort();      
    return new StandardModel { Categories = categories, MyItems = myItems };
 }

 private MyModel getMyItem(MyItem myItem, string category)
   {
     var categoryIdentifierIndex = myItem.Description.LastIndexOf(Delimiters.CategoryDescriptionDelimiter);
     var description = categoryIdentifierIndex != -1 ? myItem.Description.Substring(categoryIdentifierIndex + 1, (myItem.Description.Length - categoryIdentifierIndex + 1))) : myItem.Description;

     return new MyModel{ Name = myItem.Name, Description = myItem.Description, Category = category };
   }


 public class StandardModel
  {       
    public List<string> Categories { get; set; }
    public List<MyModel> MyItems { get; set; }        
  }

今、私はLinqで同じことをしようとしていますが、以下まで到達しました。得られた結果から、カテゴリを区別して並べ替えることができます。単一のクエリで実行できる方法はありますか?

var result = myItems.Where(myItem => !string.IsNullOrEmpty(myItem.Description))                                    
             .Select(ci => new MyModel
               {
                 Name = ci.Name,
                 Category =  ci.Description.Split('*')[0],
                 Description = ci.Description.Split('*')[2]
               }).ToList();

カテゴリとそのアイテムが欲しい。おそらく、ここで group by を使用する必要があるかもしれません。

提案してください

4

1 に答える 1