Option Explicit
Dim this_month_1st As Date '処理月の1日
Dim start_year As Long '集計開始年
Dim start_year_1st As Date
Public Sub 受注実績まとめ()
Dim ws As Worksheet 'ワーク
Dim sh1 As Worksheet '受注
Dim sh2 As Worksheet '実績
Dim sh3 As Worksheet 'まとめ
Dim maxrow As Long
Dim maxcol As Long
Dim lrow As Long
Dim wrow As Long
Dim mrow As Long
Dim yyyy As Long
Dim mm As Long
Dim pkey As String
Dim key As String
Dim col As Long
Set ws = Worksheets.Add(after:=Worksheets(Worksheets.Count)) '作業用シートを作成する
Set sh1 = Worksheets("JUTYU")
Set sh2 = Worksheets("JISSEKI")
Set sh3 = Worksheets("まとめ")
Application.ScreenUpdating = False
start_year = sh3.Cells(1, "B").Value
start_year_1st = DateSerial(start_year, 1, 1)
yyyy = Year(sh3.Cells(1, "D").Value)
mm = Month(sh3.Cells(1, "D").Value)
this_month_1st = DateSerial(yyyy, mm, 1)
maxcol = sh3.Cells(2, Columns.Count).End(xlToLeft).Column 'まとめシートの2行目の最終列を求める
sh3.Rows("3:" & Rows.Count).Clear 'まとめシートの3行以降をクリア
'作業用シートへJUTYUシートを転記する
wrow = 1
maxrow = sh1.Cells(Rows.Count, "A").End(xlUp).Row 'JUTYUシート最終行を求める
For lrow = 2 To maxrow
ws.Cells(wrow, "A").Value = sh1.Cells(lrow, "J").Value 'コード1
ws.Cells(wrow, "B").Value = sh1.Cells(lrow, "M").Value 'コード2
ws.Cells(wrow, "C").Value = sh1.Cells(lrow, "C").Value '品名1
ws.Cells(wrow, "D").Value = sh1.Cells(lrow, "L").Value '品名2
ws.Cells(wrow, "E").Value = sh1.Cells(lrow, "A").Value '日付
ws.Cells(wrow, "F").Value = sh1.Cells(lrow, "F").Value '受注数量
wrow = wrow + 1
Next
'続けて、作業用シートへJISSEKIシートを転記する
maxrow = sh2.Cells(Rows.Count, "A").End(xlUp).Row '最終行を求める
For lrow = 2 To maxrow
ws.Cells(wrow, "A").Value = sh2.Cells(lrow, "F").Value 'コード1
ws.Cells(wrow, "C").Value = sh2.Cells(lrow, "B").Value '品名1
ws.Cells(wrow, "D").Value = sh2.Cells(lrow, "E").Value '品名2
ws.Cells(wrow, "E").Value = sh2.Cells(lrow, "A").Value '日付
ws.Cells(wrow, "G").Value = sh2.Cells(lrow, "H").Value '実績数量
wrow = wrow + 1
Next
'作業用シートをソートする(1回のSortで指定可能なキーは3つ迄なので、2回に分けてソートする)
ws.Activate
Range("A1").Sort key1:=Range("D1")
Range("A1").Sort key1:=Range("A1"), key2:=Range("B1"), key3:=Range("C1")
'作業用シートを順に処理し、まとめシートへ転記する
pkey = ""
mrow = -2
For lrow = 1 To wrow - 1
key = ws.Cells(lrow, "A").Value & "|" & ws.Cells(lrow, "B").Value & "|" & ws.Cells(lrow, "C").Value & "|" & ws.Cells(lrow, "D").Value
'コード1、コード2、品名1、品名2の何れかが変われば、グループが変わったことになる
If key <> pkey Then
'グループ変更時の処理
mrow = mrow + 5
'罫線上側
sh3.Range(sh3.Cells(mrow, 1), sh3.Cells(mrow, maxcol)).Borders(xlEdgeTop).LineStyle = xlContinuous
sh3.Cells(mrow, "F").Offset(0, 0).Value = "受注"
sh3.Cells(mrow, "F").Offset(1, 0).Value = "実績"
sh3.Cells(mrow, "F").Offset(2, 0).Value = "内示"
sh3.Cells(mrow, "F").Offset(3, 0).Value = "見込み"
sh3.Cells(mrow, "F").Offset(4, 0).Value = "合計"
sh3.Cells(mrow, "A").Value = ws.Cells(lrow, "A").Value 'コード1
sh3.Cells(mrow, "B").Value = ws.Cells(lrow, "B").Value 'コード2
sh3.Cells(mrow, "D").Value = ws.Cells(lrow, "C").Value '品名1
sh3.Cells(mrow, "E").Value = ws.Cells(lrow, "D").Value '品名2
End If
'受注数量の加算
If ws.Cells(lrow, "F").Value <> "" Then
'受注数量が空白でないなら、日付から加算対象となる列を算出する
col = GetIndex(ws.Cells(lrow, "E").Value, 1)
If col > 0 Then
'加算対象となる列があるなら、その列へ加算する
sh3.Cells(mrow, col).Value = sh3.Cells(mrow, col).Value + ws.Cells(lrow, "F").Value '受注
sh3.Cells(mrow + 4, col).Value = sh3.Cells(mrow + 4, col).Value + ws.Cells(lrow, "F").Value '合計
End If
End If
'実績数量の加算
If ws.Cells(lrow, "G").Value <> "" Then
'実績数量が空白でないなら、日付から加算対象となる列を算出する
col = GetIndex(ws.Cells(lrow, "E").Value, 2)
If col > 0 Then
'加算対象となる列があるなら、その列へ加算する
sh3.Cells(mrow + 1, col).Value = sh3.Cells(mrow + 1, col).Value + ws.Cells(lrow, "G").Value '実績
sh3.Cells(mrow + 4, col).Value = sh3.Cells(mrow + 4, col).Value + ws.Cells(lrow, "G").Value '合計
End If
End If
pkey = key '前回キーを記憶
Next
If mrow > 0 Then
'罫線下側
sh3.Range(sh3.Cells(mrow + 4, 1), sh3.Cells(mrow + 4, maxcol)).Borders(xlEdgeBottom).LineStyle = xlContinuous
End If
'作業用シートを削除(削除時、警告を出さないようにする)
Application.DisplayAlerts = False
ws.Delete
Application.DisplayAlerts = True
Application.ScreenUpdating = True
sh3.Activate
sh3.Cells(1, 1).Select
MsgBox ("完了")
End Sub
Private Function GetIndex(ByVal data_date As Date, ByVal kind As Long) As Long
Dim data_year As Long
GetIndex = -1
'集計開始年より前は、集計しない
If data_date < start_year_1st Then Exit Function
If kind = 1 Then
'受注の場合、処理月より前の月は処理しない
If data_date < this_month_1st Then Exit Function
Else
'実績の場合、処理月以降の月は処理しない
If data_date >= this_month_1st Then Exit Function
End If
'加算対象列の算出
data_year = Year(data_date)
GetIndex = 6 + (data_year - start_year) * 12 + Month(data_date)
End Function
Option Explicit

Dim this_month_1st As Date '処理月の1日
Dim start_year As Long      '集計開始年
Dim start_year_1st As Date
Public Sub 受注実績まとめ()
    Dim ws As Worksheet     'ワーク
    Dim sh1 As Worksheet    '受注
    Dim sh2 As Worksheet    '実績
    Dim sh3 As Worksheet    'まとめ
    Dim maxrow As Long
    Dim maxcol As Long
    Dim lrow As Long
    Dim wrow As Long
    Dim mrow As Long
    Dim yyyy As Long
    Dim mm As Long
    Dim pkey As String
    Dim key As String
    Dim col As Long
    Set ws = Worksheets.Add(after:=Worksheets(Worksheets.Count))    '作業用シートを作成する
    Set sh1 = Worksheets("JUTYU")
    Set sh2 = Worksheets("JISSEKI")
    Set sh3 = Worksheets("まとめ")
    Application.ScreenUpdating = False
    start_year = sh3.Cells(1, "B").Value
    start_year_1st = DateSerial(start_year, 1, 1)
    yyyy = Year(sh3.Cells(1, "D").Value)
    mm = Month(sh3.Cells(1, "D").Value)
    this_month_1st = DateSerial(yyyy, mm, 1)
    maxcol = sh3.Cells(2, Columns.Count).End(xlToLeft).Column   'まとめシートの2行目の最終列を求める
    sh3.Rows("3:" & Rows.Count).Clear    'まとめシートの3行以降をクリア
    '作業用シートへJUTYUシートを転記する
    wrow = 1
    maxrow = sh1.Cells(Rows.Count, "A").End(xlUp).Row 'JUTYUシート最終行を求める
    For lrow = 2 To maxrow
        ws.Cells(wrow, "A").Value = sh1.Cells(lrow, "J").Value        'コード１
        ws.Cells(wrow, "B").Value = sh1.Cells(lrow, "M").Value        'コード２
        ws.Cells(wrow, "C").Value = sh1.Cells(lrow, "C").Value        '品名1
        ws.Cells(wrow, "D").Value = sh1.Cells(lrow, "L").Value        '品名2
        ws.Cells(wrow, "E").Value = sh1.Cells(lrow, "A").Value        '日付
        ws.Cells(wrow, "F").Value = sh1.Cells(lrow, "F").Value        '受注数量
        wrow = wrow + 1
    Next
    '続けて、作業用シートへJISSEKIシートを転記する
    maxrow = sh2.Cells(Rows.Count, "A").End(xlUp).Row '最終行を求める
    For lrow = 2 To maxrow
        ws.Cells(wrow, "A").Value = sh2.Cells(lrow, "F").Value        'コード１
        ws.Cells(wrow, "C").Value = sh2.Cells(lrow, "B").Value        '品名1
        ws.Cells(wrow, "D").Value = sh2.Cells(lrow, "E").Value        '品名2
        ws.Cells(wrow, "E").Value = sh2.Cells(lrow, "A").Value        '日付
        ws.Cells(wrow, "G").Value = sh2.Cells(lrow, "H").Value        '実績数量
        wrow = wrow + 1
    Next
    '作業用シートをソートする（1回のSortで指定可能なキーは３つ迄なので、2回に分けてソートする）
    ws.Activate
    Range("A1").Sort key1:=Range("D1")
    Range("A1").Sort key1:=Range("A1"), key2:=Range("B1"), key3:=Range("C1")
    '作業用シートを順に処理し、まとめシートへ転記する
    pkey = ""
    mrow = -2
    For lrow = 1 To wrow - 1
        key = ws.Cells(lrow, "A").Value & "|" & ws.Cells(lrow, "B").Value & "|" & ws.Cells(lrow, "C").Value & "|" & ws.Cells(lrow, "D").Value
        'コード１、コード２、品名１、品名２の何れかが変われば、グループが変わったことになる
        If key <> pkey Then
            'グループ変更時の処理
            mrow = mrow + 5
            '罫線上側
            sh3.Range(sh3.Cells(mrow, 1), sh3.Cells(mrow, maxcol)).Borders(xlEdgeTop).LineStyle = xlContinuous
            sh3.Cells(mrow, "F").Offset(0, 0).Value = "受注"
            sh3.Cells(mrow, "F").Offset(1, 0).Value = "実績"
            sh3.Cells(mrow, "F").Offset(2, 0).Value = "内示"
            sh3.Cells(mrow, "F").Offset(3, 0).Value = "見込み"
            sh3.Cells(mrow, "F").Offset(4, 0).Value = "合計"
            sh3.Cells(mrow, "A").Value = ws.Cells(lrow, "A").Value  'コード１
            sh3.Cells(mrow, "B").Value = ws.Cells(lrow, "B").Value  'コード２
            sh3.Cells(mrow, "D").Value = ws.Cells(lrow, "C").Value  '品名1
            sh3.Cells(mrow, "E").Value = ws.Cells(lrow, "D").Value  '品名2
        End If
        '受注数量の加算
        If ws.Cells(lrow, "F").Value <> "" Then
            '受注数量が空白でないなら、日付から加算対象となる列を算出する
            col = GetIndex(ws.Cells(lrow, "E").Value, 1)
            If col > 0 Then
                '加算対象となる列があるなら、その列へ加算する
                sh3.Cells(mrow, col).Value = sh3.Cells(mrow, col).Value + ws.Cells(lrow, "F").Value         '受注
                sh3.Cells(mrow + 4, col).Value = sh3.Cells(mrow + 4, col).Value + ws.Cells(lrow, "F").Value '合計
            End If
        End If
        '実績数量の加算
        If ws.Cells(lrow, "G").Value <> "" Then
            '実績数量が空白でないなら、日付から加算対象となる列を算出する
            col = GetIndex(ws.Cells(lrow, "E").Value, 2)
            If col > 0 Then
                '加算対象となる列があるなら、その列へ加算する
                sh3.Cells(mrow + 1, col).Value = sh3.Cells(mrow + 1, col).Value + ws.Cells(lrow, "G").Value '実績
                sh3.Cells(mrow + 4, col).Value = sh3.Cells(mrow + 4, col).Value + ws.Cells(lrow, "G").Value '合計
            End If
        End If
        pkey = key  '前回キーを記憶
    Next
    If mrow > 0 Then
        '罫線下側
        sh3.Range(sh3.Cells(mrow + 4, 1), sh3.Cells(mrow + 4, maxcol)).Borders(xlEdgeBottom).LineStyle = xlContinuous
    End If
    '作業用シートを削除（削除時、警告を出さないようにする）
    Application.DisplayAlerts = False
    ws.Delete
    Application.DisplayAlerts = True
    Application.ScreenUpdating = True
    sh3.Activate
    sh3.Cells(1, 1).Select
    MsgBox ("完了")
End Sub

Private Function GetIndex(ByVal data_date As Date, ByVal kind As Long) As Long
    Dim data_year As Long
    GetIndex = -1
    '集計開始年より前は、集計しない
    If data_date < start_year_1st Then Exit Function
    If kind = 1 Then
        '受注の場合、処理月より前の月は処理しない
        If data_date < this_month_1st Then Exit Function
    Else
        '実績の場合、処理月以降の月は処理しない
        If data_date >= this_month_1st Then Exit Function
    End If
    '加算対象列の算出
    data_year = Year(data_date)
    GetIndex = 6 + (data_year - start_year) * 12 + Month(data_date)
End Function

