返回列表 上一主題 發帖

[發問] 以A2儲存格為檔名,做成小計報表

回復 10# PJChen
  1. Sub Ex()
  2. Dim A As Range
  3. fs = ThisWorkbook.Sheets("VBA").[A2] 'A2為檔名
  4. With Workbooks(fs)
  5. .Sheets("報表").UsedRange = .Sheets("報表").UsedRange.Value
  6. .Sheets("報表").Copy '把報表複製到新檔案
  7. .Close 0 '關閉a.xlsx
  8. End With
  9. Application.DisplayAlerts = False '關閉對話方塊
  10. ActiveWorkbook.SaveAs "D:\抽水機數據分析_值.xlsx" '將新檔儲存
  11. With Workbooks("抽水機數據分析_值.xlsx") '報表新檔案
  12. With .Sheets("報表")
  13. .UsedRange = .UsedRange.Value '去除公式
  14. .Range("A1").CurrentRegion.Subtotal GroupBy:=4, Function:=xlSum, TotalList:=Array(10, 11), _
  15.         Replace:=True, PageBreaks:=False, SummaryBelowData:=True '已連續日期分組小計
  16. .[A:D].Delete '刪除A:D欄位
  17. If .[B3] = "" Then .Rows(3).Delete
  18. With .Range("F:F").SpecialCells(xlCellTypeFormulas)
  19. .Offset(, -1) = "計"
  20. For Each A In .Cells '畫框線
  21. A = Round(A, 2) '四捨五入
  22. A.Offset(, 1) = Round(A.Offset(, 1), 2) '四捨五入
  23.    For i = 7 To 10
  24.        A.Offset(, -1).Resize(, 3).Borders(i).Weight = xlThick '框線寬度
  25.        A.Offset(, -1).Resize(, 3).Borders(i).ColorIndex = 3 '框線顏色
  26.    Next
  27. Next
  28. End With
  29. End With
  30. .Save
  31. End With
  32. Application.DisplayAlerts = True
  33. End Sub
複製代碼
學海無涯_不恥下問

TOP

回復 11# Hsieh

大大,
我測試後發現 四捨五入後 小計與總計會有小數差,不知要如何解決?

TOP

回復 11# Hsieh

大大,
麻煩您很多,不要再改了.
我想改為四捨五入小數第三位,這樣就不會有不符的情形了.

TOP

回復 11# Hsieh

大大,
勞煩您幫忙改個小地方,在最後欄位的小計及總計會出現黑線,可否改成以下的樣式? 謝謝!!
最後的小計.jpg

TOP

回復 14# PJChen
程式碼都有註解,請了解程式碼就能自行更改
  1. Sub Ex()
  2. Dim A As Range
  3. fs = ThisWorkbook.Sheets("VBA").[A2] 'A2為檔名
  4. With Workbooks(fs)
  5. .Sheets("報表").UsedRange = .Sheets("報表").UsedRange.Value
  6. .Sheets("報表").Copy '把報表複製到新檔案
  7. .Close 0 '關閉a.xlsx
  8. End With
  9. Application.DisplayAlerts = False '關閉對話方塊
  10. ActiveWorkbook.SaveAs "D:\抽水機數據分析_值.xlsx" '將新檔儲存
  11. With Workbooks("抽水機數據分析_值.xlsx") '報表新檔案
  12. With .Sheets("報表")
  13. .UsedRange = .UsedRange.Value '去除公式
  14. .Range("A1").CurrentRegion.Subtotal GroupBy:=4, Function:=xlSum, TotalList:=Array(10, 11), _
  15.         Replace:=True, PageBreaks:=False, SummaryBelowData:=True '已連續日期分組小計
  16. .[A:D].Delete '刪除A:D欄位
  17. If .[B3] = "" Then .Rows(3).Delete
  18. With .Range("F:F").SpecialCells(xlCellTypeFormulas)
  19. .Offset(, -1) = "計"
  20. For Each A In .Cells '畫框線
  21. A = Round(A, 3) '四捨五入小數點3位
  22. A.Offset(, 1) = Round(A.Offset(, 1), 3) '四捨五入小數點3位
  23.    For i = 7 To 10
  24.        A.Offset(, -1).Resize(, 3).Borders(i).Weight = xlThick '框線寬度
  25.        A.Offset(, -1).Resize(, 3).Borders(i).ColorIndex = 3 '框線顏色
  26.    Next
  27. Next
  28. End With
  29. For i = 1 To .Cells(.Rows.Count, "E").End(xlUp).CurrentRegion.Rows.Count '總計表格畫框線
  30.     For j = 7 To 10
  31.        With .Cells(.Rows.Count, "E").End(xlUp).CurrentRegion.Rows(i).Borders(j)
  32.           .Weight = xlThick
  33.           .ColorIndex = 3
  34.         End With
  35.     Next
  36. Next
  37. End With
  38. .Save
  39. End With
  40. Application.DisplayAlerts = True
  41. End Sub
複製代碼
學海無涯_不恥下問

TOP

回復 15# Hsieh

感謝大人,執行無誤!!

TOP

        靜思自在 : 地上種了菜,就不易長草;心中有善,就不易生惡。
返回列表 上一主題