-1
Q
エクセルVB
A
答えて
0
コメントに記載されているように、提案された時間単位の分割は、グラフの結果に正確さや信用を与えるようには見えません。私は、開始時間と停止時間がこれらの部門に丸められた最大10分のセグメントを提案します。
真夜中から午前1時までは0時とみなされ、午後11時から真夜中は23時間とみなされます。時間は変換することができますが、それは生産的なコーディングではないようです。代わりに、適切な時間括弧を使用するようにユーザーを教育します。
Option Explicit
Sub create_time_duration()
Dim h As Long, trw As Long, drw As Variant
With Worksheets("Sheet6")
.Range("E:EU").EntireColumn.Delete
For h = 0 To 23
With .Cells(1, 6 + h * 6).Resize(1, 6)
.EntireColumn.ColumnWidth = 0.6
.Merge
With .Resize(1, 1)
.NumberFormat = "hh:mm"
.Value = TimeSerial(h, 0, 0)
.HorizontalAlignment = xlCenter
.VerticalAlignment = xlCenter
.Font.Size = 10
End With
End With
Next h
For trw = 2 To .Cells(Rows.Count, "C").End(xlUp).Row
If Not IsEmpty(.Cells(trw, "A")) Then
drw = Application.Match(.Cells(trw, "A").Value2, .Columns("E"), 0)
If IsError(drw) Then
.Cells(Rows.Count, "E").End(xlUp).Offset(1, 0) = .Cells(trw, "A").Value2
drw = Application.Match(.Cells(trw, "A").Value2, .Columns("E"), 0)
End If
.Cells(drw, "F").Resize(1, 144).NumberFormat = ";;;"
End If
.Cells(drw, (Hour(.Cells(trw, "B").Value) + 1) * 6 + _
CLng(Minute(.Cells(trw, "B").Value)/10)). _
Resize(1, Hour(.Cells(trw, "C").Value - .Cells(trw, "B").Value) * 6 + _
CLng(Minute(.Cells(trw, "C").Value - .Cells(trw, "B").Value)/10)) = 1
Next trw
With .Range(.Cells(2, "E"), .Cells(Rows.Count, "E").End(xlUp))
With .Resize(.Rows.Count, 144).Offset(0, 1)
.FormatConditions.Delete
.FormatConditions.Add Type:=xlExpression, Formula1:="=AND(F2)"
With .FormatConditions(.FormatConditions.Count)
With .Interior
.Color = vbGreen
End With
.StopIfTrue = False
End With
End With
End With
End With
End Sub
時間枠グラフをドレスアップする任意のセルの枠線を作成することができます。
create_time_duration Subプロシージャの前に関連する問題
- 1. エクセルのポップアップボックスのマクロVBスクリプト
- 2. エクセルVBは私をエクセルの底に連れて行きます
- 3. エクセル
- 4. エクセル
- 5. エクセル
- 6. (エクセル)
- 7. エクセル
- 8. (エクセル)
- 9. エクセル
- 10. エクセル
- 11. エクセル:
- 12. エクセル
- 13. エクセル
- 14. エクセル
- 15. エクセル
- 16. エクセル
- 17. エクセル
- 18. エクセル
- 19. SSMS:エクセル
- 20. エクセル:VBA
- 21. エクセル - セル
- 22. はエクセル
- 23. エクセル:タイトル
- 24. エクセル2013
- 25. エクセル - VBA
- 26. はエクセル
- 27. エクセル - 式
- 28. エクセル - 式
- 29. COUNTAエクセル
- 30. はエクセル
ExcelであるVBAを使用することができます。マクロを作成するオプションが用意されています。そして、あなたの現在の状況では、時間データを解析する何かが細胞に必要となります。あなたのイメージから、あなたは数時間についての情報を必要とし、開始終了時から背景色と境界線を現在のセルに設定します。 –
データをループして「時間」機能を使用してセルの位置を取得し、その範囲に色を付けることができます。 – MutjayLee
ちょっとしたことに:私はあなたがデータを扱う/表示する方法が好きです。グラフの「5時に来た」という5時30分の番組と、16時35分から17時24分のほぼ1時間も全く表示されません。だから、一度人々があなたのグラフの弱点を知ると、一人一人は一日中 "in"だったかのように見えるかもしれませんが、実際には2時間30分そこにとどまっていました:5時30分6時10分7時: 30 out 8:10 in 9:30 out 10:10 ... – Ralph