質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.41%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

LINQ

LINQとはLanguage INtegrated Queryの略で、「統合言語クエリ」という意味です。C#やVisual Basicといった言語のコード内に記述することができるクエリです。

Q&A

解決済

2回答

1028閲覧

LINQのグループごとの抽出について

Zaki1192

総合スコア4

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

LINQ

LINQとはLanguage INtegrated Queryの略で、「統合言語クエリ」という意味です。C#やVisual Basicといった言語のコード内に記述することができるクエリです。

1グッド

0クリップ

投稿2023/01/12 09:49

前提

LINQについての質問です。
対象をグループごとに処理する方法(groopby句?)の使い方が理解できていないため、ご教示いただけると幸いです。

実現したいこと

Productクラスは袋のサイズを表すint型の変数、満杯かどうかを表すbool型の変数で構成されています。
サイズの異なる袋の一覧があったと仮定して、満杯の袋のサイズの一覧を取得したいです。

該当のソースコード

C#

1using System; 2using System.Linq; 3 4namespace MyApp // Note: actual namespace depends on the project name. 5{ 6 internal class Program 7 { 8 static void Main(string[] args) 9 { 10 List<Product> p_lst = new List<Product>(); 11 p_lst.Add(new Product(10,false)); 12 p_lst.Add(new Product(10, true)); 13 p_lst.Add(new Product(50, false)); 14 p_lst.Add(new Product(50, false)); 15 p_lst.Add(new Product(100, true)); 16 p_lst.Add(new Product(200, false)); 17 18 //Falseしかない袋のサイズの一覧を取得したい 19 List<int> shoudAddSize_lst = p_lst 20 //.******* //Falseしかないproductをサイズ別に抽出 21 .Select(x => x.Size) 22 .Distinct() 23 .ToList(); 24 25 foreach (var size in shoudAddSize_lst) 26 { 27 Console.WriteLine(size);//求めたいListの一覧:50,200 28 } 29 } 30 } 31 32 public class Product 33 { 34 public int Size; 35 public bool Canput; 36 37 public Product(int size,bool canput) 38 { 39 Size = size;//袋の大きさ 40 Canput = canput;//True→入れることが可能 False→満杯 41 } 42 } 43 44}

補足情報(FW/ツールのバージョンなど)

VisualStudio2022 コンソールアプリ

TN8001👍を押しています

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kikukiku

2023/01/12 09:59

下記で欲しいデータが取得できているのかな? groopbyは使っていないです。 List<int> shoudAddSize_lst = p_lst .Where(x => x.Canput == False) .Select(x => x.Size) .Distinct() .ToList();
Zaki1192

2023/01/12 10:05

kikukikuさん、質問ありがとうございます。 List<int> shoudAddSize_lst = p_lst .Where(x => x.Canput == false) .Select(x => x.Size) .Distinct() .ToList(); Where句で絞ると結果が10,50,200になりますが、この場合10は抽出したくないです(trueが存在するため) Falseだけしかないサイズ(50,200)を取り出したいです。
guest

回答2

0

ベストアンサー

ラムダ式だけで完結させようとしてつまづいてました。
冗長的なコードになってしまいましたが、一応自己解決しました。

冗長でもやりたいことができるのがまず一番ですね^^
LINQで済ますならこんな感じでしょうか。

cs

1var p_lst = new List<Product> 2{ 3 new Product(10, false), 4 new Product(10, true), 5 new Product(50, false), 6 new Product(50, false), 7 new Product(100, true), 8 new Product(200, false), 9}; 10 11var shoudAddSize_lst = p_lst 12 13 // サイズごとにグループ化 14 .GroupBy(x => x.Size) 15 16 // 同グループの中ですべて満杯のものに絞り込み 17 .Where(x => x.All(p => !p.Canput)) 18 19 // ↑と意味は同じだがAnyのほうが効率はいいか(ひとつでも入れられるものが見つかったら打ち切るので) 20 // 同グループの中で「ひとつでも入れられるものがあれば」の否定(=すべて満杯) 21 //.Where(x => !x.Any(p => p.Canput)) 22 23 // グループ化のKey(Size)をリストに 24 .Select(x => x.Key).ToList(); 25 26Console.WriteLine(string.Join(",", shoudAddSize_lst)); // 50,200 27 28 29public class Product 30{ 31 public int Size; 32 public bool Canput; 33 34 public Product(int size, bool canput) 35 { 36 Size = size; 37 Canput = canput; 38 } 39}

Enumerable.All<TSource>(IEnumerable<TSource>, Func<TSource,Boolean>) メソッド (System.Linq) | Microsoft Learn

Enumerable.Any メソッド (System.Linq) | Microsoft Learn

投稿2023/01/12 10:58

編集2023/08/15 15:33
TN8001

総合スコア9528

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Zaki1192

2023/01/12 23:06

TN8001さん、ありがとうございます。 まさに思い描いていたものです! 「ひとつでも入れられるものがあれば」の否定(=すべて満杯)が目から鱗でした。 LINQ以外の他の部分も記述の修正ありがとうございます。 参考にさせていただきます。 kikukikuさん、TN8001さん、ここまでありがとうございました。
guest

0

ラムダ式だけで完結させようとしてつまづいてました。
冗長的なコードになってしまいましたが、一応自己解決しました。

C#

1using System; 2using System.Linq; 3 4namespace MyApp // Note: actual namespace depends on the project name. 5{ 6 internal class Program 7 { 8 static void Main(string[] args) 9 { 10 List<Product> p_lst = new List<Product>(); 11 p_lst.Add(new Product(10,false)); 12 p_lst.Add(new Product(10, true)); 13 p_lst.Add(new Product(50, false)); 14 p_lst.Add(new Product(50, false)); 15 p_lst.Add(new Product(200, false)); 16 17 18 List<int> shoudAddSize_lst = new List<int>(); 19 20 var query = p_lst.GroupBy(x => x.Size); 21 foreach(var group in query) 22 { 23 bool shouldAddsize = true; 24 foreach(var p in group) 25 { 26 if(p.Canput==true) 27 { 28 shouldAddsize = false; 29 break; 30 } 31 } 32 if(shouldAddsize==true) 33 { 34 shoudAddSize_lst.Add(group.Key); 35 } 36 } 37 38 foreach (var size in shoudAddSize_lst) 39 { 40 Console.WriteLine(size);//求めたいListの一覧:50,200 41 } 42 } 43 } 44 45 public class Product 46 { 47 public int Size; 48 public bool Canput; 49 50 public Product(int size,bool canput) 51 { 52 Size = size;//袋の大きさ 53 Canput = canput;//True→入れることが可能 False→満杯 54 } 55 } 56}

投稿2023/01/12 10:40

Zaki1192

総合スコア4

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2023/01/12 23:55

> LINQについての質問です と自分で質問欄で条件をつけたのだから、部分的にしか linq を使ってない案を自己解決とするのはいかがなものかと思いますけど。
Zaki1192

2023/01/13 00:31

修正しました。
退会済みユーザー

退会済みユーザー

2023/01/13 03:05

対応ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.41%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問