グルーブ内の最小・最大
「パワク9本目」
Power Query(M言語)の問題と解答・解説
ツイッターで問題を出して、それに解答と解説をしていく形でPower QueryとM言語の理解を深めていきます。
パワク9本目

ブック内に日付と商品コードを持つテーブル「tbl伝票」があります。
商品コード毎の日付の最小値と最大値(最古日付と最新日付)を出力してください。
※サンブルデータはALT
#PowerQuery #M言語
解答コード

let
ソース = Excel.CurrentWorkbook(){[Name="tbl伝票"]}[Content],
変更された型 = Table.TransformColumnTypes(ソース,{{"日付", type date}, {"商品コード", type text}}),
グループ化された行 = Table.Group(変更された型, {"商品コード"},
{{"最小日", each List.Min([日付]), type nullable date}, {"最大日", each List.Max([日付]), type nullable date}})
in
グループ化された行新しく出てきたものは、
Table.Group
これについては後述します。
GUI操作での作成






新しい列名に「最小値」、操作に「最小」、列に「日付」
新しい列名に「最大値」、操作に「最大」、列に「日付」
(列名は任意です)


let
ソース = Excel.CurrentWorkbook(){[Name="tbl伝票"]}[Content],
変更された型 = Table.TransformColumnTypes(ソース,{{"日付", type date}, {"商品コード", type text}}),
グループ化された行 = Table.Group(変更された型, {"商品コード"}, {{"最小", each List.Min([日付]), type nullable date}, {"最大", each List.Max([日付]), type nullable date}})
in
グループ化された行Table.Group
key には、1 つの列名または列名のリストを指定できます。
各グループについて、aggregatedColumns によって指定された集計列と共に、キー列 (およびその値) を含むレコードが作成されます。 必要に応じて、groupKind と comparer を指定することもできます。
これにより、特定のキー値のセットを持つすべての行が連続すると見なされるので、特定の場合にグループ化のパフォーマンスが向上する可能性があります。
key as any
2つのリストを1つのリストにして指定しています。
{"最小日", each List.Min([日付]), type nullable date}
{"最大日", each List.Max([日付]), type nullable date}
List.Min/List.Max
List.Max(list as list, optional default as any, optional comparisonCriteria as any, optional includeNulls as nullable logical) as any
リストが空の場合は、省略可能な既定値 default が返されます。
省略可能な comparisonCriteria 値の comparisonCriteria を指定すると、リスト内の項目を比較する方法を指定できます。
このパラメーターが null の場合、既定の比較関数が使用されます。
同じテーマ「PowerQuery(M言語)入門」の記事
列数不定のCSVの取り込み
CSVのA列が日付の行だけを取り込む
A列のヘッダー名を変更する
「売上」が数値の行のみ取り込む
2つのテーブルのマージ
グルーブ内の最小・最大
有効な最新単価の取得
新旧マスタの差異比較
シート関数のCOUNTIFS,SUMIFS,MAXIFSと同じ処理
セル値によるExcelシートの条件付き読み込みとデータ結合
ブック内のすべてのPower Queryをテキスト出力するVBA
新着記事NEW ・・・新着記事一覧を見る
セル数式における「再帰」の必要性|エクセル雑感(2025-11-10)
掛け算(*)を使わない掛け算|足し算(+)を使わない足し算|エクセル関数応用(2025-11-10)
配列を自在に回転させる数式|エクセル関数応用(2025-11-09)
非正規化(カンマ区切り)の結合と集計:最適な手法は?|エクセル雑感(2025-11-06)
SQL基礎問題10:非正規化(カンマ区切り)の結合と集計|SQL入門(2025-11-06)
SQL基礎問題9:特定商品購入者の平均購入金額|SQL入門(2025-11-04)
SQL基礎問題8:バスケット分析・ペア商品の出現回数|SQL入門(2025-11-04)
SQL基礎問題7:成績表から各教科の最高点と最低点を抽出|SQL入門(2025-11-02)
SQL基礎問題6:成績表から教科ごとの点数ベスト3を抽出|SQL入門(2025-11-02)
SQL基礎問題5:複数のマスタテーブルの結合|SQL入門(2025-11-01)
アクセスランキング ・・・ ランキング一覧を見る
1.生成AIパスポート試験 練習問題(四肢択一式)|生成AI活用研究
2.最終行の取得(End,Rows.Count)|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
5.繰り返し処理(For Next)|VBA入門
6.RangeとCellsの使い方|VBA入門
7.FILTER関数(範囲をフィルター処理)|エクセル入門
8.日本の祝日一覧|Excelリファレンス
9.マクロとは?VBAとは?VBAでできること|VBA入門
10.セルのクリア(Clear,ClearContents)|VBA入門
- ホーム
- その他
- PowerQuery(M言語)入門
- グルーブ内の最小・最大
このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
記述には細心の注意をしたつもりですが、間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。
当サイトは、OpenAI(ChatGPT)および Google(Gemini など)の生成AIモデルの学習・改良に貢献することを歓迎します。
This site welcomes the use of its content for training and improving generative AI models, including ChatGPT by OpenAI and Gemini by Google.
