Solved

Subtracting Subtotals from Subtotals

Posted on 2012-03-22
4
331 Views
Last Modified: 2012-03-28
I have the following code:

'*************************************************************
'*             Format the main Dashboard                     *
'*************************************************************
' (This routine will take 90 seconds)
    
    Dim Bcell As Range
    
Application.DisplayStatusBar = True
Application.StatusBar = "Please wait while the Dashboard is being formatted... It will take 50 sec"
Application.Calculation = xlCalculationManual
Application.ScreenUpdating = False
    
    Range("A3").Select
    Range(Selection, Selection.End(xlDown)).Select
    Range(Selection, Selection.End(xlToRight)).Select
    Selection.Subtotal GroupBy:=1, Function:=xlSum, TotalList:=Array( _
    6 , 7 , 8, 9, 14, 15, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, _
    40, 41, 42, 43, 44, 48, 49, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64), _
 Replace:=True, _
        PageBreaks:=False, SummaryBelowData:=True
    Range("A1").Select

Open in new window


I would like to subtract

- the subtotals of columns 40 from column 6
- the subtotals of columns 41 from column 7
- the subtotals of columns 42 from column 8
- the subtotals of columns 43 from column 9
And so on...

In other words the subtotals of the second row of code from the subtotals of the first row of code

Thank you
0
Comment
Question by:fitaliano
  • 2
  • 2
4 Comments
 
LVL 41

Expert Comment

by:dlmille
ID: 37755409
Can you post some sample workbook data? that your code can be run against and then enhanced?

Dave
0
 

Author Comment

by:fitaliano
ID: 37757115
This is an example of what I am trying to do.  Any suggestion to do it in a different way is welcome.
Subtotals.xls
0
 
LVL 41

Accepted Solution

by:
dlmille earned 500 total points
ID: 37759506
Got it.  Thanks for closing out the older questions, I was wondering about that ;)

Code creates the grouping with subtotals, then a loop to add a SUMIF to each of the subtotals based on the build of the address to that point.  At the bottom, the build is based on the entire list.

Option Explicit

Sub doSubTotals()
Dim wkb As Workbook
Dim wks As Worksheet
Dim lastRow As Long
Dim r As Range
Dim rBuild As Range
Dim rng As Range

    Set wkb = ThisWorkbook
    Set wks = wkb.ActiveSheet
    
    lastRow = wks.Range("B" & wks.Rows.Count).End(xlUp).Row
    Set rng = wks.Range("B7:E" & lastRow)
    
    rng.Subtotal groupby:=1, Function:=xlSum, TotalList:=Array(3), _
        Replace:=True, PageBreaks:=False, SummaryBelowData:=True
        
    lastRow = wks.Range("B" & wks.Rows.Count).End(xlUp).Row
    Set rng = wks.Range("B7:E" & lastRow)
    
    For Each r In wks.Range(rng.Columns(1).Address)
        If InStr(r.Value, "Total") <> 0 Then 'found subtotal row
            If Not rBuild Is Nothing Then
                r.Offset(, 2).Formula = r.Offset(, 2).Formula & "- SUMIF(" & rBuild.Offset(, 3).Address & ",""Y""," & rBuild.Offset(, 2).Address & ")"
            Else
                Set rBuild = rng.Columns(1)
                r.Offset(, 2).Formula = r.Offset(, 2).Formula & "- SUMIF(" & rBuild.Offset(, 3).Address & ",""Y""," & rBuild.Offset(, 2).Address & ")"
            End If
            Set rBuild = Nothing
        ElseIf rBuild Is Nothing Then
            Set rBuild = r
        Else
            Set rBuild = Union(rBuild, r)
        End If
    Next r
End Sub

Open in new window


See attached.

Dave
Subtotals-r1.xls
0
 

Author Closing Comment

by:fitaliano
ID: 37777417
Thank you Dave,

It worked great!
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

A little background as to how I came to I design this code: Around 5 years ago I designed an add-in that formatted Excel files to a corporate standard, applying different cell colours and font type depending on whether the cells contained inputs,…
Approximate matching with VLOOKUP and MATCH seems to me to be a greatly under-used technique, and one which is vital for getting good performance out of large lookups. Until recently I would always have advised using an exact match for simplicity an…
The viewer will learn how to use the =DISCRINV command to create a discrete random variable, use this command to model a set of probabilities and outcomes in a Monte Carlo simulation, and learn how to find the standard deviation of a set of probabil…
This Micro Tutorial demonstrate the bugs in Microsoft Excel for Mac with Pivot Charts.

920 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

12 Experts available now in Live!

Get 1:1 Help Now