Excel VBA質問箱 IV

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

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


10875 / 76734 ←次へ | 前へ→

【71404】Re:ソート→集計をマクロで
質問  ゆうか  - 12/2/29(水) 15:01 -

引用なし
パスワード
   UO3様

いつもご親切にありがとうございます。
書式設定は難なく進められました。
新たに表の作成位置をC10からにしようとコードを触ったところ
タイトル行(C10:H10)がおかしな位置に移動してしまって
いくらコードを眺めても何が違っているのか分からずとまってしまいました。
一度見ていただけますか?
よろしくお願いします。

Sub sort()
Application.ScreenUpdating = False
  With Worksheets("DB")
    .Range("f4").AutoFilter _
      Field:=5, Criteria1:=">=1"
      .Range("f4").CurrentRegion.SpecialCells(xlCellTypeVisible).Copy _
      Worksheets("集計").Range("a1")
      .AutoFilterMode = False
  End With
  Worksheets("集計").Activate
  Columns("A:F").EntireColumn.AutoFit
Application.ScreenUpdating = True
End Sub
Sub 請求書作成()
  Dim v As Variant
  Dim z As Long
  Dim i As Long
  Dim k As Long
  Dim dic As Object
  Dim dKey As String
  Dim c As Range
  Dim w As Variant
 
  Set dic = CreateObject("Scripting.Dictionary")
 
  With Sheets("集計")
    z = .Range("A1").CurrentRegion.Rows.Count - 1
    ReDim v(1 To z, 1 To 6)
    For Each c In .Range("A2", .Range("A" & .Rows.Count).End(xlUp))
      dKey = Join(WorksheetFunction.Index(c.Resize(, 4).Value, 1, 0), vbTab)
      If Not dic.exists(dKey) Then
        dic(dKey) = dic.Count + 1
        i = dic(dKey)
        v(i, 1) = c.Value
        v(i, 2) = c.Offset(, 1).Value
        v(i, 3) = c.Offset(, 2).Value
        v(i, 4) = c.Offset(, 3).Value
      End If
      i = dic(dKey)
      v(i, 5) = v(i, 5) + c.Offset(, 4).Value
      v(i, 6) = v(i, 6) + c.Offset(, 5).Value
    Next
  End With
 
  With Sheets("請求書")
    .Cells.ClearContents
    .Range("C10:H10").Value = Sheets("集計").Range("A1:F1").Value
    .Range("C11").Resize(dic.Count, 6).Value = v
    .Rows(2).Resize(dic.Count).sort key1:=.Range("C11"), Order1:=xlAscending, Header:=xlNo
    .Range("C" & dic.Count + 2).Value = "合計"
    .Range("H" & dic.Count + 2).FormulaR1C1 = "=SUM(R2C:R[-1]C)"
  
    '============ 罫線他の書式設定 開始
  
    .Cells.Borders.LineStyle = xlNone 'すでにひかれている罫線があればそれを削除
  
    '1行目 タイトル行 ★あらかじめ書式設定しておけば、コード処理は不要
    With .Range("C10:H10")
      .HorizontalAlignment = xlCenter
      .VerticalAlignment = xlCenter
    End With
    '合計行
    With .Range("C" & dic.Count + 2)
      .Resize(, 5).HorizontalAlignment = xlCenterAcrossSelection
      .Offset(, 5).HorizontalAlignment = xlRight
      .Resize(, 6).VerticalAlignment = xlCenter
    End With
    'データ領域
    With .Range("C2", .Range("E" & dic.Count + 1))
      .HorizontalAlignment = xlCenter
      .VerticalAlignment = xlCenter
    End With
    With .Range("F2", .Range("H" & dic.Count + 1))
      .HorizontalAlignment = xlRight
      .VerticalAlignment = xlCenter
    End With

    '罫線
    With .Range("C1").CurrentRegion.Borders
        .LineStyle = xlContinuous
        .Weight = xlThin
    End With
  
    .Columns("C:H").EntireColumn.AutoFit '★これは、あらかじめ書式設定しておけばコード処理は不要
  
    '============ 罫線他の書式設定 終了
    .Select
    End With
 
    Application.ScreenUpdating = True

    Set dic = Nothing
    MsgBox "合計処理完了"

    End Sub
4 hits

【71348】ソート→集計をマクロで ゆうか 12/2/24(金) 13:35 質問
【71356】Re:ソート→集計をマクロで UO3 12/2/24(金) 19:36 回答
【71357】Re:ソート→集計をマクロで UO3 12/2/24(金) 19:39 回答
【71362】Re:ソート→集計をマクロで ゆうか 12/2/25(土) 1:03 質問
【71370】Re:ソート→集計をマクロで UO3 12/2/25(土) 14:19 発言
【71372】Re:ソート→集計をマクロで UO3 12/2/25(土) 19:01 発言
【71374】Re:ソート→集計をマクロで UO3 12/2/26(日) 1:38 発言
【71404】Re:ソート→集計をマクロで ゆうか 12/2/29(水) 15:01 質問
【71414】Re:ソート→集計をマクロで UO3 12/3/1(木) 10:17 回答
【71424】Re:ソート→集計をマクロで ゆうか 12/3/1(木) 13:12 発言
【71433】Re:ソート→集計をマクロで UO3 12/3/2(金) 11:26 発言
【71434】Re:ソート→集計をマクロで UO3 12/3/2(金) 11:43 回答
【71358】Re:ソート→集計をマクロで Hirofumi 12/2/24(金) 19:40 発言
【71361】Re:ソート→集計をマクロで ゆうか 12/2/25(土) 0:56 質問

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