
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
この回答へのお礼
お礼日時:2018/08/21 13:07
ご回答ありがとうございます。
やりたいことができました。ありがとうございました。
記載いただいた内容からも学ぶことがたくさんあり勉強になりました。
またなにかありましたらご指導の程宜しくお願いいたします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Excelで、あるセルの値に応じて...
-
Cellsのかっこの中はどっちが行...
-
複数の列の値を結合して別の列...
-
rowsとcolsの意味
-
複数csvを横に追加していくマク...
-
【VBA】2つのシートの値を比較...
-
4月~3月まで12カ月横に並んだ...
-
IIF関数の使い方
-
VBAを使用し、数式を無視した最...
-
VBA: 2列のリストボックスの2列...
-
エクセル 2つの表の並べ替え
-
VBAのFind関数で結合セルを検索...
-
データグリッドビューの一番最...
-
C# Datagridview 行ヘッダーの...
-
Excel VBA_2000ハイパーリンク...
-
targetをA列のセルに限定するに...
-
VBAに関するメッセージ
-
VB2005EE:DataGridViewでチェ...
-
VBA 何かしら文字が入っていたら
-
Worksheets メソッドは失敗しま...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
VBA sum ワークシートChange
-
Excelで、あるセルの値に応じて...
-
Worksheets メソッドは失敗しま...
-
URLのリンク切れをマクロを使っ...
-
【VBA】2つのシートの値を比較...
-
rowsとcolsの意味
-
Cellsのかっこの中はどっちが行...
-
vba 2つの条件が一致したら...
-
IIF関数の使い方
-
B列の最終行までA列をオート...
-
VBAでのリスト不一致抽出について
-
複数の列の値を結合して別の列...
-
VBA 何かしら文字が入っていたら
-
VBAのFind関数で結合セルを検索...
-
エクセル 2つの表の並べ替え
-
DataGridViewに空白がある場合...
-
文字列の結合を空白行まで実行
-
データグリッドビューの一番最...
-
【VBA】複数行あるカンマ区切り...
-
ExcelVBAでテキストルーレット...
おすすめ情報