Improve company productivity with a Business Account.Sign Up

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 536
  • Last Modified:

Excel AutoSum

Hello,
I have a workBook with multiple sheets (varies) ,
I'm trying to Auto Sum Columns (M,N,P,Q), Starting Raw M2,N2,P2,Q2.
And the summary be at the end of the columns (M,N,P,Q).

Do the same on all sheets.
The number of Raws varies.

I wonder if there is a vb code that can do this.

Any help is appreciated.
0
W.E.B
Asked:
W.E.B
  • 5
  • 4
1 Solution
 
redmondbCommented:
Hi, Wass_QA.

Please see attached. If the code finds that the last used cell in column M is simply the total for that column then it assumes that this sheet has already be done and so it skips it. Sheet1 is like this.

The code is...
Option Explicit

Sub Auto_Total()
Dim xSheet    As Worksheet
Dim xLast_row As Long
Dim xCol      As Variant

For Each xSheet In ThisWorkbook.Sheets
    If xSheet.UsedRange.Rows.Count < 0 Then Debug.Print "?!"
    xLast_row = xSheet.[A1].SpecialCells(xlLastCell).Row
    If xSheet.Range("M" & xLast_row).Formula = "=SUM(M2:M" & xLast_row - 1 & ")" Then
        MsgBox ("Total found for """ & xSheet.Name & """ - sheet bypassed.")
    Else
        For Each xCol In Array("M", "N", "P", "Q")
            xSheet.Range(xCol & xLast_row + 1).Formula = Replace("=SUM(|2:|" & xLast_row & ")", "|", xCol)
        Next
    End If
Next

End Sub

Open in new window

Regards,
Brian.Auto-Total.xls
0
 
W.E.BAuthor Commented:
Hello redmondb,
Thanks again for your help,

The code is working well on all sheets except on sheet 1

thanks,
0
 
redmondbCommented:
Wass_QA,

The code is working well on all sheets except on sheet 1
Nope - please see my first post! Would you like something different?

Thanks,
Brian.
0
Free Tool: ZipGrep

ZipGrep is a utility that can list and search zip (.war, .ear, .jar, etc) archives for text patterns, without the need to extract the archive's contents.

One of a set of tools we're offering as a way to say thank you for being a part of the community.

 
W.E.BAuthor Commented:
Hello,
it is not giving me any totals on sheet1,
All other sheets Total is working great.

Thanks,
0
 
redmondbCommented:
Wass_QA,

This was explained in my first post! What do you want me to do when the macro finds that there are already totals on the last line? If I simply create a new set of totals then they'll be completely wrong - giving double the correct answer!

Instead of doing something that I know is wrong, I bypass the sheet. Again, what would you prefer me to do?

(BTW, the version above copes badly with a sheet with no data. I have a new version to handle this but I'll wait for your answer to this post before sending it.)

Thanks,
Brian.
0
 
W.E.BAuthor Commented:
ok, sorry,
I figured it out,
The Total was coming up way down the column.
I had some characters I didnt delete.

thank you very much.
0
 
W.E.BAuthor Commented:
Thank you very much.
0
 
redmondbCommented:
Wass_QA,

The attached handles sheets with no data. The code is...
Option Explicit

Sub Auto_Total()
Dim xSheet    As Worksheet
Dim xLast_row As Long
Dim xCol      As Variant

For Each xSheet In ThisWorkbook.Sheets
    If xSheet.UsedRange.Rows.Count < 0 Then Debug.Print "?!"
    xLast_row = xSheet.[A1].SpecialCells(xlLastCell).Row
    If xLast_row < 2 Then
        MsgBox ("No data in """ & xSheet.Name & """ - sheet bypassed.")
    Else
        If xSheet.Range("M" & xLast_row).Formula = "=SUM(M2:M" & xLast_row - 1 & ")" Then
            MsgBox ("Total found for """ & xSheet.Name & """ - sheet bypassed.")
        Else
            For Each xCol In Array("M", "N", "P", "Q")
                xSheet.Range(xCol & xLast_row + 1).Formula = Replace("=SUM(|2:|" & xLast_row & ")", "|", xCol)
            Next
        End If
    End If
Next

End Sub

Open in new window

Regards,
Brian.Auto-Total-V2.xls
0
 
redmondbCommented:
Thanks, Wass_QA, but please be sure to use the version in my last post!

As I may have mentioned to you before, I keep an eye on "my" closed questions for at least a couple of weeks, so if you have any further issues with this code please feel free to post here.

Regards,
Brian.
0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

Featured Post

Free Tool: IP Lookup

Get more info about an IP address or domain name, such as organization, abuse contacts and geolocation.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

  • 5
  • 4
Tackle projects and never again get stuck behind a technical roadblock.
Join Now