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

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

新規登録して質問してみよう
ただいま回答率
85.46%
VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

Q&A

解決済

3回答

196閲覧

VBAの日付処理について

Pun_hiro

総合スコア32

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

0グッド

0クリップ

投稿2021/02/10 02:22

ExcelVBAの処理についてお教えいただけないでしょうか

A列(開始日) B列(終了日)
2020/01/01 2021/01/01

というデータがあり、出力結果を
2020/01
2020/02
2020/03
2020/04
2020/05
2020/06
2020/07
2020/08
2020/09
2020/10
2020/11
2020/12
2021/01
というように縦列に出力したいと思っております。
その場合、VBAで記述するとどの様になるでしょうか...
よろしくお願いいたします。

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

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

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

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

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

guest

回答3

0

A2セルに開始日、B2セルに終了日が入力されていて、
C列に出力するとして、

vba

1 Dim i As Long 2 3 For i = 0 To DateDiff("m", Range("A2"), Range("B2")) - 1 4 Cells(i + 1, 3).Value = Format(DateAdd("m", i, Range("A2")), "yyyy/mm") 5 Next

投稿2021/02/10 03:01

hatena19

総合スコア33790

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

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

Pun_hiro

2021/02/10 03:15

!! ありがとうございます!
guest

0

ベストアンサー

こんな感じでいかがでしょうか。

VBA

1Sub sample() 2 Dim startDate, endDate, c As Range, i 3 4 startDate = Range("A1").Value 5 endDate = Range("B1").Value 6 Set c = Range("A3") 7 For i = 0 To DateDiff("m", startDate, endDate) 8 c.Offset(i).Value = DateAdd("m", i, startDate) 9 Next 10 c.CurrentRegion.NumberFormatLocal = "yyyy/mm" 11End Sub 12

投稿2021/02/10 02:45

jinoji

総合スコア4585

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

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

Pun_hiro

2021/02/10 02:50

まさにそのとおりです。 分かりづらい説明で申し訳ありません。 ありがとうございます。
guest

0

データを一行にそろえた後にソート機能を使えばいいのではないでしょうか。
並べ替え
自力でソートプログラムを組むならアルゴリズムの話になりますが。

投稿2021/02/10 02:28

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

Pun_hiro

2021/02/10 02:35

ご回答ありがとうございます。 行ごとに A列(開始日) B列(終了日) 2020/01/01 2021/01/01 と保持しているデータを 開始日と終了日の期間の年月のみを 1列で表示したいのですが....
退会済みユーザー

退会済みユーザー

2021/02/10 02:42 編集

てっきり元データは数行あって記載されていないと思いましたが、問題を切り分けると 開始日と終了日を1件ずつ取得する 開始日と終了日の日付を削除する 開始日と終了日を比較して何か月分の開きがあるか確認する 開きのある分の月を生成する。 全てをソートして1列にする 作成完了 想定する手順はこういう形でいいんですかね?
Pun_hiro

2021/02/10 02:43 編集

はい!そのとおりです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問