いつの間にか便利な日付系の関数「EDate関数」と「EOMonth関数」が追加されていたので、簡単にご紹介。
EDate関数
EDate関数はnか月後の日付を求める関数で、DateAdd関数の単位を「月」にしたときと同じ動作(のよう)。
動作イメージはこんな感じ。
data:image/s3,"s3://crabby-images/5b006/5b006d7a294b00c532d4bb1871547d55c0fb349f" alt=""
data:image/s3,"s3://crabby-images/5b006/5b006d7a294b00c532d4bb1871547d55c0fb349f" alt=""
月末の日付に対してEDate関数を使用した場合は指定した月後の月末の日付を返してくれる。
data:image/s3,"s3://crabby-images/390d4/390d4c0de3f8b284c8029ba4cfd3c5f32153d200" alt=""
data:image/s3,"s3://crabby-images/390d4/390d4c0de3f8b284c8029ba4cfd3c5f32153d200" alt=""
EOMonth関数
EOMonth関数は指定した月後の月末の日付を返してくれる。
動作イメージはこんな感じ。
data:image/s3,"s3://crabby-images/ebf61/ebf61129114334e5200dd9350399b9c40daca8af" alt=""
data:image/s3,"s3://crabby-images/ebf61/ebf61129114334e5200dd9350399b9c40daca8af" alt=""
このEOMonthを使って、指定した年月の全日付をコレクションに入れる式は以下のようになるかな。
※もっと簡単な式あるかもだけど。
※もっと簡単な式あるかもだけど。
With({start:Date(求めたい年, 求めたい月, 1)}, With({end:EOMonth(start, 0)}, ClearCollect(dates, ForAll(Sequence(DateDiff(start, end, TimeUnit.Days) + 1), DateAdd(start, ThisRecord.Value - 1, TimeUnit.Days) ) ) ) )
動作イメージ。
data:image/s3,"s3://crabby-images/1c16e/1c16eb7bffe0f50714fb251fa7bcc83748d6fa41" alt=""
data:image/s3,"s3://crabby-images/1c16e/1c16eb7bffe0f50714fb251fa7bcc83748d6fa41" alt=""
月末の日付を簡単に使用できるようになったのでとても助かる。
コメント