Excel VBA質問箱 IV

当質問箱は、有志のボランティア精神のおかげで成り立っています。
問題が解決したら、必ずお礼をしましょうね。
本サイトの基本方針をまとめました。こちら をご一読ください。

投稿種別の選択が必要です。ご注意ください。
迷惑投稿防止のため、URLの入力を制限しています。ご了承ください。


40170 / 76732 ←次へ | 前へ→

【41663】Re:3つの表を1つに集計
回答  Kein  - 06/8/18(金) 16:48 -

引用なし
パスワード
   ちから技ですが、こちらのテストでは成功しました。
完成図を表示するシートの名前を "集計" とします。

Sub Data_集計()
  Dim Sh As Worksheet, WS As Worksheet
  Dim C As Range, FR As Range, MyR As Range
  Dim Ary As Variant, MyV As Variant, V As Variant
  Dim i As Long, Cnt As Long
  Dim List() As String
 
  Set Sh = Worksheets("集計")
  Ary = Array("担当者", "得意先名", _
  "売上金額1", "売上金額2", "売上金額3")
  Application.ScreenUpdating = False
  Sh.Cells.ClearContents
  Sh.Range("A1:E1").Value = Ary
  With Worksheets("Sheet3")
   MyV = .Range("A2", .Range("A65536").End(xlUp)).Value
  End With
  Cnt = UBound(MyV): ReDim List(i): List(i) = "z"
  For Each WS In Sheets(Array("Sheet1", "Sheet2", "Sheet3"))
   For Each C In WS.Range("D2", WS.Range("D65536").End(xlUp))
     If IsError(Application.Match(C.Value, List(), 0)) Then
      i = i + 1: ReDim Preserve List(i)
      List(i) = C.Value
     End If
   Next
  Next
  For Each V In List
   If CStr(V) <> "z" Then
     With Sh.Range("B65536").End(xlUp)
      .Offset(2).Resize(Cnt).Value = MyV
      .Offset(2, -1).Value = CStr(V)
     End With
   End If
  Next
  i = 1
  For Each WS In Sheets(Array("Sheet1", "Sheet2", "Sheet3"))
   For Each C In WS.Range("D2", WS.Range("D65536").End(xlUp))
     xR = Application.Match(C.Value, Sh.Range("A:A"), 0)
     Set FR = Sh.Cells(xR, 1).CurrentRegion _
     .Find(C.Offset(, -3).Value, , xlValues)
     If Not FR Is Nothing Then
      FR.Offset(, i).Value = C.Offset(, -2).Value
      Set FR = Nothing
     End If
   Next
   i = i + 1
  Next
  Sh.Rows("2:2").Delete xlSiftUp
  Set MyR = Sh.Range("B1", Sh.Range("B65536").End(xlUp).Offset(1)) _
  .SpecialCells(4)
  MyR.Offset(, -1).FormulaR1C1 = "=R[-" & Cnt & "]C&"" 計"""
  Intersect(MyR.EntireRow, Sh.Range("C:E")).FormulaR1C1 = _
  "=SUM(R[-" & Cnt & "]C:R[-1]C)"
  Application.ScreenUpdating = True
  Erase List: Set MyR = Nothing: Set Sh = Nothing
End Sub

0 hits

【41447】3つの表を1つに集計 Help me!! 06/8/10(木) 14:59 質問
【41484】Re:3つの表を1つに集計 ナイスプログラム 06/8/12(土) 0:38 質問
【41645】Re:3つの表を1つに集計 ℃素人 06/8/18(金) 8:52 発言
【41838】Re:3つの表を1つに集計 ナイスプログラム 06/8/23(水) 22:48 回答
【41663】Re:3つの表を1つに集計 Kein 06/8/18(金) 16:48 回答

40170 / 76732 ←次へ | 前へ→
ページ:  ┃  記事番号:
2610219
(SS)C-BOARD v3.8 is Free