![見出し画像](https://assets.st-note.com/production/uploads/images/49223349/rectangle_large_type_2_8efa335194f9b06a44e57a0781effe62.png?width=1200)
パワークエリで生年月日から年齢を計算する方法※うるう年対応版あり※【Excel PowerQuery】
パワークエリで、生年月日の日付をもとに、ある基準日時点の年齢を計算する方法を紹介します。
![画像1](https://assets.st-note.com/production/uploads/images/48733283/picture_pc_0a50a74433ef9f1f6d871449f285da72.png?width=1200)
![](https://assets.st-note.com/img/1695041560557-hkcReT1Tbn.png?width=1200)
ちなみに、クエリを使わず、ワークシート上にある生年月日と基準日から年齢を計算したい場合は『DATEDIF』関数や、
![画像2](https://assets.st-note.com/production/uploads/images/48733445/picture_pc_01d19f32a84a4322c0a61157c3a71af5.png?width=1200)
『YEARFRAC』関数を使って求めることができます。
![画像3](https://assets.st-note.com/production/uploads/images/48733677/picture_pc_d6bf3688414e2bb3a5783a62cf567c70.png?width=1200)
厳密に日単位でみると、『DATEDIF』と『YEARFRAC』では、歳を取るタイミングが若干違ってきます。
大雑把な年齢の傾向を知りたい、といった程度であればどちらでも構いませんが、日単位で正確な年齢を求めたいのであれば『DATEDIF』の方が正しいですね。
![画像4](https://assets.st-note.com/production/uploads/images/48734462/picture_pc_82572d8d19d7aa64d66d54e8cdd90541.png)
シート上に存在する生年月日から年齢を求めるのであれば、上に書いたような関数を利用すればいいです。
一方、他のExcelブックやCSVファイル等からクエリで直接データを取得した場合、パワークエリの中でワークシート関数は使えませんので、パワークエリ上で年齢を計算することになります。
その方法をこれから解説します。
![](https://assets.st-note.com/img/1695035252161-BRbra4sSY5.png?width=1200)
やりたいこと
クエリで取得したデータの生年月日から、基準とする日付時点の年齢を、パワークエリ上で計算したい。
![画像5](https://assets.st-note.com/production/uploads/images/48805309/picture_pc_07668d43784805fc822b36e877019cbd.png)
手順1. データの取得
生年月日と、年齢を求める基準となる年月日が含まれているデータを、パワークエリに取得し、データ型を日付に変換します。
![画像6](https://assets.st-note.com/production/uploads/images/48878572/picture_pc_92f1eac67ba23ff6b1f52a8b5e3db0dd.png?width=1200)
※パワークエリにデータを取得する方法や、データ型を変更する方法が分からない場合は、パワークエリの基本的な使い方を解説している動画の中で説明していますので、そちらをご覧ください。
手順2. 日数の列を算出
『生年月日』の列を選択してから、列の追加>日付>期間を押します。
![画像7](https://assets.st-note.com/production/uploads/images/48878777/picture_pc_5b0ccdf57dabf54ab7a1ab195f591a52.png?width=1200)
![画像8](https://assets.st-note.com/production/uploads/images/49031561/picture_pc_92aebcdf8430ff6e52d5b9a8ed57301b.png?width=1200)
手順3. 基準日からの日数に変更
この時点で追加された『期間』というのは、『生年月日』の日付から今現在の日付までの日数です。
それぞれの『生年月日』から今現在の年齢を計算したいのであれば、手順3はスキップしてしてください。
今現在ではなく、『基準年月日』時点の年齢を計算したいのであれば、数式バーを以下のように変更します。
![画像9](https://assets.st-note.com/production/uploads/images/49031758/picture_pc_4b43625afd5e1beda7c01db07a86c651.png?width=1200)
= Table.AddColumn(変更された型, "期間",
each Date.From(DateTime.LocalNow()) - [生年月日], type duration)
↓↓↓
《太字部分を書き換える》
↓↓↓
= Table.AddColumn(変更された型, "期間",
each [基準年月日] - [生年月日], type duration)
これで『期間』の値が、生年月日から今現在までの日数ではなく、生年月日から基準年月日までの日数に変更されます。
![画像10](https://assets.st-note.com/production/uploads/images/49031866/picture_pc_2c9dd28fe9fc89bcfe57ec9f1a7f3491.png?width=1200)
手順4. 期間を年単位に変換
『期間』の値は『生年月日』から『基準年月日』までの日数なので、これを年数に変換します。
![画像11](https://assets.st-note.com/production/uploads/images/49185459/picture_pc_28714acc87f8d36b42a945b7b7de7f99.png?width=1200)
![画像12](https://assets.st-note.com/production/uploads/images/49185506/picture_pc_bb4c61f476dede40cc935c9cc924d624.png?width=1200)
手順5. 年数の小数点以下を切り捨て
この時点で『期間』の値は『生年月日』から『基準年月日』までの年数にはなっているのですが、小数点以下まで表示されています。
普通は年齢を言う場合「22.4歳」とは言いませんので、この小数点以下の数値は切り捨てます。
![画像13](https://assets.st-note.com/production/uploads/images/49185833/picture_pc_a51dfbeff92f51ada38a89ffa80bd117.png?width=1200)
![画像14](https://assets.st-note.com/production/uploads/images/49185868/picture_pc_0e8eefbc363f121156705ded4bcb66d1.png?width=1200)
手順6. ヘッダー名を変更
最期に『期間』となっているヘッダー名を『年齢』に変更します。
![画像15](https://assets.st-note.com/production/uploads/images/49186082/picture_pc_a30c725a6172a576af260a5cfa5600f5.png)
おわり?
以上の手順で、『生年月日』から『基準年月日』時点の年齢をパワークエリ上で求めることができました。
![画像16](https://assets.st-note.com/production/uploads/images/49186174/picture_pc_b506e32764a1a0e54dee9f23dda8747f.png)
ところが、実はこの方法だと正確な年齢を計算することはできていません。
こんな感じで、ワークシート関数のDATEDIFで計算した年齢と、先ほどのクエリによって計算した年齢とでは、歳を取る日が微妙にズレます。
![画像18](https://assets.st-note.com/production/uploads/images/49196664/picture_pc_6931af76a9d5b0a378d92f9d02849a39.png?width=1200)
どちらが正しいかといったら、DATEDIFで計算した年齢ですよね。
誕生日が2011/1/15の人は、2021/1/15に10歳になりますから。
うるう年問題
なぜクエリで計算した場合は、実際よりも早い日付で歳をとってしまうのでしょうか?
![画像21](https://assets.st-note.com/production/uploads/images/49198306/picture_pc_a93202a28dba7a5fbf146af3c12646c9.png?width=1200)
それは、クエリで日数を年数に変換した部分のステップが原因です。
![画像17](https://assets.st-note.com/production/uploads/images/49186365/picture_pc_7aefc65abbc1637e45e437e425c41981.png?width=1200)
![画像20](https://assets.st-note.com/production/uploads/images/49197193/picture_pc_5c3bb74f43142ce05b15965e1f5efbbb.png?width=1200)
このステップの数式を見てみると「 / 365」と書いてある部分があります。
つまり、厳密に言えば、これは日数を年数に変換しているわけではなく、日数を「÷365」しているだけということです。
普通の年であれば1年は365日なので÷365で問題ありません。
ところが4年に1度はうるう年がありますので、1年の日数が366日の場合があります。
先ほどのクエリの場合は、『生年月日』から『基準年月日』の間にうるう年があるかどうかは一切考慮していませんので、本来であれば366日経過した場合にはじめて1歳とカウントするところを、365日経過した時点で1歳とカウントしてしまっている、ということです。
『生年月日』から『基準年月日』が離れているほど、その間にうるう年が挟まる回数が増えますので、年齢カウントの日付が前にズレていきます。
![画像21](https://assets.st-note.com/production/uploads/images/49198313/picture_pc_0ac68b5ec35b5d238b47b930a514b0f5.png?width=1200)
大雑把な年齢の傾向を分析したい場合などは、年齢のカウントが数日分ズレても大して影響ありませんので、簡易的に上記の方法で年齢をカウントして問題ないとは思いますが、例えば法定書類に使う年齢を計算したい場合などは、『基準年月日』の時点での年齢を厳密にカウントしなければいけませんので、上で解説したようなクエリを使うことはできません。
パワークエリ上で、うるう年を考慮したうえで、厳密に年齢をカウントするためのカスタム関数を作成してみましたので、ここから下ではそのカスタム関数と使い方を解説します。
カスタム関数クエリによる年齢計算 ※うるう年対応版
『生年月日』と『基準年月日』を含むテーブルをクエリで取得します。
![画像22](https://assets.st-note.com/production/uploads/images/49219597/picture_pc_59433de4897546a037e0bd1936db522d.png)
![画像23](https://assets.st-note.com/production/uploads/images/49219692/picture_pc_ef067615a0c1ecec630ec0ab34f7ed03.png?width=1200)
空のクエリを作成します。
![画像33](https://assets.st-note.com/production/uploads/images/49221166/picture_pc_dada7aa93a16881e202f71fcf40679c7.png?width=1200)
![画像26](https://assets.st-note.com/production/uploads/images/49219848/picture_pc_b190f3f387d3cdc7156d0319a9d62d73.png?width=1200)
作成した空のクエリで詳細エディターを開きます。
![画像26](https://assets.st-note.com/production/uploads/images/49219965/picture_pc_f0c2df627bf422eba918b61be2d733a5.png?width=1200)
![画像27](https://assets.st-note.com/production/uploads/images/49219981/picture_pc_c9f508a553878b7ae7e9932eeea328cb.png?width=1200)
詳細エディターを、以下のカスタム関数のコードに置き換えます。
よければサポートしていただけると嬉しいです😀 有用な記事や動画を制作していけるように頑張ります❗️