Solved

Excel VB-Add total price where date is the same

Posted on 2009-03-31
5
464 Views
Last Modified: 2012-05-11
Hi,

Please view the snapshot. I'm trying to add the total price (column "Z") where the date (i.e. serial date) is the same (column "X"). Then have the total for each date copied to Column "AA".

For instance, where column "X" = 39788 get the value of column "Z" for the given row. Then let Column "AA" row 2 = 39788 and Column "AB" row 2 = (total of column "Z" where "X" = 39788).

Hope that makes sense.

Thank you,
vkimura
excel-aggregate-total-where-date.png
0
Comment
Question by:Victor Kimura
  • 3
5 Comments
 
LVL 50

Expert Comment

by:Dave Brett
ID: 24034868
can you pls post a sample file as opposed to a picture :)
Cheers
Dave
0
 

Author Comment

by:Victor Kimura
ID: 24035004
Hi brettdj,

Okay, here it is.
excel-aggregate-total-where-date.xls
0
 

Author Comment

by:Victor Kimura
ID: 24035112
I have this thus far where the commented numbers below the Dims are the serial dates. Everything is manually fixed. I'm thinking create an array with the serial dates and loop through them.

Sub MatchSerialDate2()
    Dim N As Long
    Dim payForDay As Long
    Dim totalPayForDay As Long
    ' 39788,39795,39786,39793,39787,39794,39785,39792
    For N = 2 To 3
        If Cells(N, 24) = 39788 Then
            payForDay = Cells(N, 19) 'pay for the given row
            totalPayForDay = Cells(2, 29) 'aggregate toal pay for the day
            Cells(2, 29) = payForDay + totalPayForDay
            Cells(2, 28) = 39788
        End If
    Next N
End Sub
0
 
LVL 59

Accepted Solution

by:
Saurabh Singh Teotia earned 500 total points
ID: 24035297
Vkumra,
Is this what you are looking for..?
Saurabh...
 

Sub MatchSerialDate2()

    Dim rng As Range, rng1 As Range, cell As Range, rng2 As Range, I As Long

    Set rng = Range("X2:X" & Cells(65536, "X").End(xlUp).Row)

    Set rng1 = Range("Z2:Z" & Cells(65536, "X").End(xlUp).Row)

    I = 2

    For Each cell In rng

        Set rng2 = Range("AA2:AA" & I)

        If cell.Value = cell.Offset(0, 1).Value And Application.WorksheetFunction.CountIf(rng2, cell.Value) = 0 Then

            Range("AA" & I).Value = cell.Value

            Range("AB" & I).Value = Application.WorksheetFunction.SumIf(rng, cell.Value, rng1)

            I = I + 1

        End If

    Next cell
 

End Sub

Open in new window

0
 

Author Closing Comment

by:Victor Kimura
ID: 31565111
Thank you, saurabh726. That works.
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

Suggested Solutions

Title # Comments Views Activity
highlight duplicate entry 16 30
sql server query from excel 3 57
File not loading into PowerPivot 4 9
Simple Excel re-arrange data.  (I can work in access too). 8 50
This code takes an Excel list of URL’s and adds a header titled “URL List”. It then searches through all URL’s in column “A”, looking for duplicates. When a duplicate is found, it is moved to the top of the list. The duplicate URL’s are then highlig…
Freeze panes is an option within all variants of Excel to enable parts of a sheet to remain stationary when the cursor is in another part of the sheet. This is a very useful feature which is overlooked or under used.
The view will learn how to download and install SIMTOOLS and FORMLIST into Excel, how to use SIMTOOLS to generate a Monte Carlo simulation of 30 sales calls, and how to calculate the conditional probability based on the results of the Monte Carlo …
This Micro Tutorial demonstrates using Microsoft Excel pivot tables, how to reverse engineer competitors' marketing strategies through backlinks.

867 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

20 Experts available now in Live!

Get 1:1 Help Now