
No.1ベストアンサー
- 回答日時:
以下で如何でしょうか。
記録は下方向へ伸びていくと思いますので、C列、E列に値が入力された場合にイベント処理するようにしました。
B/D列の表示形式は「日付」、C/E/F列の表示形式は「時刻」にしてください。
もしF列の表示が24時間を超える場合はプログラムのコメント部分に従って修正してください。
Private Sub Worksheet_Change(ByVal Target As Range)
Dim nw As Date
Dim dt1 As Date
Dim dt2 As Date
' C列/E列以外の場合は何もしない
If Target.Column <> 3 And Target.Column <> 5 Then Exit Sub
nw = Now()
'入力が数値の場合、左側のセルに「今」の年月日のシリアル値を書く
If IsNumeric(Target.Value) Then
Target.Offset(, -1).Value = DateSerial(Year(nw), Month(nw), Day(nw))
End If
With ActiveSheet
'入力行のC列/E列に数値の入力がある場合、差をF列に書く
If IsNumeric(.Cells(Target.row, "C")) And IsNumeric(.Cells(Target.row, "E")) Then
dt1 = CDate(.Cells(Target.row, "B").Value) + CDate(.Cells(Target.row, "C").Value)
dt2 = CDate(.Cells(Target.row, "D").Value) + CDate(.Cells(Target.row, "E").Value)
If dt1 > dt2 Then
MsgBox "B/C列の方が後の日時です。", vbExclamation
Else
'F列書き込み
.Cells(Target.row, "F").Value = dt2 - dt1
'F列の値が24時間を超える場合があるとき(表示形式を文字列にする)
'.Cells(Target.row, "F").Value = WorksheetFunction.Text(dt2 - dt1, "[h]:mm")
End If
End If
End With
End Sub
ご回答ありがとうございます。
やりたいことができました。ありがとうございました。
記載いただいた内容からも学ぶことがたくさんあり勉強になりました。
またなにかありましたらご指導の程宜しくお願いいたします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- 睡眠障害・不眠症・過眠症 睡眠について 私はどんなに睡眠時間をしっかりとっても、起きる時間帯が早いとスッキリ起きれません。 例 5 2023/05/17 14:41
- 熱中症 睡眠時間が足りないと不調で困ってます 2 2023/03/04 11:29
- 日本語 添削のお願い 2 2022/11/15 14:07
- 生活習慣・嗜好品 結局、ガンって遺伝的要因もあるのでしょうか? 2 2022/07/23 18:47
- 睡眠障害・不眠症・過眠症 睡眠についてです。 私は睡眠の質が悪いと思っています。7時間眠っても眠り足りないです。 大学生なので 3 2022/09/20 16:44
- 睡眠障害・不眠症・過眠症 睡眠時間について 私は6時間寝ないと朝が辛く1日しんどいです。 毎朝5時半起床で仕事に行きます。 3 5 2023/06/13 06:22
- 子育て 早起きすぎる1歳娘、どうしたらいいか・・ 12 2023/07/06 13:38
- 睡眠障害・不眠症・過眠症 睡眠を妨害されるとイライラする? 3 2023/06/07 12:05
- 生活習慣・嗜好品 20代前半でも日頃から血圧測定はしておくべきですか? 以前、アナフィラキシーの症状で救急車にて運ばれ 2 2022/10/21 19:13
- 子育て 赤ちゃんが朝4時半に起きます。 生後6ヶ月です。 前までは6時半起床だったのですが、 さいきんになっ 4 2022/06/15 09:30
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
vba 2つの条件が一致したら...
-
ExcelVBAでテキストルーレット...
-
Changeイベントでの複数セルの...
-
B列の最終行までA列をオート...
-
Worksheets メソッドは失敗しま...
-
【VBA】複数行あるカンマ区切り...
-
SpecialCells(xlCellTypeConsta...
-
VBScriptでfindを使うには??
-
excel vbaで日付指定で入力
-
Excelで、あるセルの値に応じて...
-
データグリッドビューの一番最...
-
【VBA】2つのシートの値を比較...
-
IIF関数の使い方
-
列全体をコピーして別の列に貼...
-
マクロを使って比較した結果の...
-
フォルダを一括で作成したいの...
-
期限を超えた日付に警告のメッ...
-
VBAで散布図(グラフ)の作成
-
ExcelVBA コンボボックスの表示
-
Excel VBA 列の表示と非表示に...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excelで、あるセルの値に応じて...
-
Worksheets メソッドは失敗しま...
-
vba 2つの条件が一致したら...
-
B列の最終行までA列をオート...
-
IIF関数の使い方
-
Cellsのかっこの中はどっちが行...
-
【VBA】2つのシートの値を比較...
-
VBAのFind関数で結合セルを検索...
-
URLのリンク切れをマクロを使っ...
-
文字列の結合を空白行まで実行
-
VBA 何かしら文字が入っていたら
-
VBAを使って検索したセルをコピ...
-
【Excel VBA】 B列に特定の文字...
-
VBAで指定範囲内の空白セルを左...
-
Changeイベントでの複数セルの...
-
VBAで、離れた複数の列に対して...
-
VBAでのリスト不一致抽出について
-
データグリッドビューの一番最...
-
rowsとcolsの意味
-
DataGridViewに空白がある場合...
おすすめ情報