Excel VBA質問箱 IV

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

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


42 / 76789 ←次へ | 前へ→

【82418】Re:sumifsを使ったVBAの作り方
発言  マナ  - 24/12/17(火) 20:09 -

引用なし
パスワード
   ▼NANAMI さん:
>
>for nextとsumifsを使って作りたいのです

Worksheets("練習15")では、ループ必要ないでしょう。

Sub test()
  Dim r1 As Range
  Dim r2 As Range
  Dim i As Long
  Dim j As Long
  
  Set r1 = Worksheets("練習15").Range("A1").CurrentRegion
  Set r2 = Worksheets("練習15_回答").Range("A1").CurrentRegion
  
  For i = 2 To r2.Rows.Count
    For j = 2 To r2.Columns.Count
      r2(i, j).Value = WorksheetFunction.SumIfs(r1.Columns(3), _
        r1.Columns(1), r2(1, j).Value, r1.Columns(2), r2(i, 1).Value)
    Next
  Next

End Sub

数式を一括で挿入して、それを値に変換すると
ープなしでできます。

Sub test2()
  Dim r1 As Range
  Dim r2 As Range
  Dim f As String

  Set r1 = Worksheets("練習15").Range("A1").CurrentRegion
  Set r2 = Worksheets("練習15_回答").Range("A1").CurrentRegion
  Set r2 = Intersect(r2, r2.Offset(1, 1))
  
  f = "=sumifs(" _
    & r1.Columns(3).Address(-1, -1, , -1) & "," _
    & r1.Columns(1).Address(-1, -1, , -1) & "," _
    & r2(0, 1).Address(-1, 0) & "," _
    & r1.Columns(2).Address(-1, -1, , -1) & "," _
    & r2(1, 0).Address(0, -1) & ")"
    
  r2.Formula = f
  r2.Value = r2.Value

End Sub

2 hits

【82417】sumifsを使ったVBAの作り方 NANAMI 24/12/17(火) 13:12 質問[未読]
【82418】Re:sumifsを使ったVBAの作り方 マナ 24/12/17(火) 20:09 発言[未読]
【82419】Re:sumifsを使ったVBAの作り方 NANAMI 24/12/18(水) 17:27 お礼[未読]

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