パワークエリのM関数「Date.AddMonths」のサムネイル
AさんAさん

特定の日付列を基準に、3か月後の日付を計算したいです。
Power Queryエディター上で日付の月数のみ計算したい場合、どうしたら良いですか?

森田森田

その場合、M関数の「Date.AddMonths」を使えば良いですよ!
では、詳細を解説していきますね。

森田貢士 公式LINEバナー

はじめに

この記事は「カスタム列」コマンドの詳細を把握していることが前提です。

参考記事

「カスタム列」コマンドの詳細は、以下の記事をご参照ください。

「Date.AddMonths」の使いどころ

入社日から本採用日を計算する等、特定の日付列を基準に月数だけ計算したいケースがありますが、Power Queryエディターには、日付列の月数を計算するためのコマンドがありません。

ワークシート上の関数でいえば、「EDATE」と類似のコマンドがないということですね。

Power Queryエディター上で日付列から指定の月数を計算した日付列を作成したい場合、「カスタム列」ダイアログ上で「Date.AddMonths」を活用しましょう。

パワークエリのM関数「Date.AddMonths」の使いどころ

Date.AddMonthsを活用することで、選択した日付列から指定の月数を前後させた日付列を作成できます。

参考記事

ワークシート上の関数の「EDATE」の詳細は、以下の記事をご参照ください。

構文

Date.AddMonthsの構文は以下の通りです。

Date.AddMonths ( dateTime , numberOfMonths )
指定された月を日付に追加します。

引数名必須データ型説明
dateTime日付、日付/時刻、日付/時刻/タイムゾーン開始日を示す日付列・日付/時刻列や定数を指定します。
numberOfMonths数値引数「dateTime」に加減算したい月数を指定します。
※負の数を指定の場合、Nか月前を計算可能

引数「dateTime」がnullの場合、Date.AddMonthsの戻り値もnullを表示。
引数「numberOfMonths」に数値以外を指定した場合、Expression.Error表示。

参考記事

必要に応じ、Microsoft Learnの「Date.AddMonths」の記事もご参照ください。

数式例・使用イメージ

「入社日」列から「本採用日」列(「入社日」列の3か月後の日付)を作成したイメージが以下です。

パワークエリのM関数「Date.AddMonths」の使用イメージ

なお、この列のデータ型は、後続のステップの内容に応じ、「日付」・「日付/時刻」・「日付/時刻/タイムゾーン」のいずれかへ変更してください。

また、カスタム列で参照している日付列は不要であれば別途削除してください。

ステップ登録手順

「カスタム列」コマンドでDate.AddMonthsを登録したい場合は、以下の手順となります。

パワークエリのM関数「Date.AddMonths」のステップ登録手順

  1. リボン「列の追加」タブをクリック
  2. 「カスタム列」をクリック
  3. 任意の列名を入力
    ※今回は「本採用日」
  4. 「d」を入力
  5. サジェストから「Date.AddMonths」を選択し、「Tab」キーで確定
  6. 「(」を入力
  7. 開始日を示す日付列を選択
    ※今回は「入社日」列
  8. コンマ(,)を入力
  9. 任意の月数を入力
    ※今回は「3」
  10. 「)」を入力
  11. 「OK」をクリック

登録したステップの変更手順

Date.AddMonthsのステップを後から変更する場合、以下の手順となります。

パワークエリのM関数「Date.AddMonths」のステップ変更手順

  1. 「追加されたカスタム列」ステップの歯車マークをクリック
  2. 任意の箇所を修正
  3. 「OK」をクリック

手順①のステップ名は「カスタム列」コマンドのデフォルトの名前(自身でリネームしている場合は別表記)。
手順①はステップ名をダブルクリックでもOK。
手順①で起動した「カスタム列」ダイアログは、ステップに設定した内容がセットされた状態。

サンプルファイルで練習しよう!

可能であれば、以下のサンプルファイルをダウンロードして、実際に操作練習をしてみてください。

サンプルファイル_PowerQueryデータ整形_Date.AddMonths.xlsx

サンプルファイルのダウンロードには無料メルマガに登録いただく必要があります(上記リンクから登録フォームへ遷移します)。

ブックを開いたら、「社員マスタ」クエリを編集(Power Queryエディター起動)し、次の手順を実施してください(今までの解説のまとめです)。
ブック起動時、「セキュリティの警告」メッセージが表示された場合は「コンテンツの有効化」をクリック。

  1. リボン「列の追加」タブをクリック
  2. 「カスタム列」をクリック
  3. 任意の列名を入力
    ※今回は「本採用日」
  4. 「d」を入力
  5. サジェストから「Date.AddMonths」を選択し、「Tab」キーで確定
  6. 「(」を入力
  7. 開始日を示す日付列を選択
    ※今回は「入社日」列
  8. コンマ(,)を入力
  9. 任意の月数を入力
    ※今回は「3」
  10. 「)」を入力
  11. 「OK」をクリック

本記事の解説と同じ結果になればOKです!

さいごに

いかがでしたでしょうか?

Date.AddMonthsを活用することで、選択した日付列から指定の月数を前後させた日付列を作成できます。

一連の整形作業の中で、日付列の月数を計算した日付列を作成したい場合に活用してみましょう!

なお、パワークエリの各種テクニックは、私の拙著でも体系的に解説していますので、こちらも参考にしてみてください。


ご参考になれば幸いですm(_ _)m

森田森田

Date.AddMonthsに慣れたら、他の日付列の作成や計算に役立つM関数もチャレンジしてみましょう。
具体的には、年/月/日を示す3列から日付列を作成できる「#date」や、日付の月の最終日を返す「Date.EndOfMonth」、日付に指定の日数を加減算できる「Date.AddDays」等です。
他にどんなM関数があるかは、Microsoft Learnの「Power Query M関数参照」も参照してみてくださいね!