Formula Sumproduct is taking very long time to update data results.

Kishan

Well-known Member
Joined
Mar 15, 2011
Messages
1,645
Office Version
  1. 2010
Platform
  1. Windows
Using Excel 2000

Hi,

I was using the macro below with only 1000 - 1500 rows, but now I want to use and check played with 59000 rows extending the range it is taking 45-55 minutes to update data results.

My enquiry is it any other formulas or VBA code which can reduce the time for update data results.

In the column "A" there is entered year.
In the column "B" there is entered results.
In the column "C" there is Check Played.

Row 3 has header.... Year, Results, check Played, and year to check 00/01 to 19/20

When I run the macro below it takes 45 - 55 minutes

*ABCDEFGHIJKLMNOPQRSTUVWXY
1
2
3YearResultsCheck Played00/0101/0202/0303/0404/0505/0606/0707/0808/0909/1010/1111/1212/1313/1414/1515/1616/1717/1818/1919/20
400/01XX10000000000000000000
500/01X | 11 | 2 | 1 | 2 | X | 1 | 1 | 2 | X00000000000000000001
601/02X | XX | X01000000000000000000
701/021 | 1 | 11 | X | X | 1 | 2 | 1 | 2 | 1 | 100000000000000000001
801/02X | 1 | 1X | 1 | 101000000000000000000
901/021 | 1 | 11 | 2 | 200000000000000000000
1002/031 | 1 | 1 | 2X | 1 | X | 1 | X | 1 | 1 | X00000000000000100000
1102/031 | X | 2 | 11 | X | 1 | X00100000000000000000
1202/031 | X | 1 | X1 | 1 | 1 | 200100000000000000000
1302/03X | X | X | 11 | X | X | 100000000000000000000
1402/03X | X | 2 | 21 | X | X | X00000000000000000000
1503/041 | 1 | 2 | 11 | X | X | 200000000000000000000
1603/04X | 1 | 1 | 11 | X | 2 | 100100000000000000000
1703/04X | 2 | X | 1 | 11 | 1 | X | 1 | 100000000000000000000
1803/041 | 1 | 1 | 1 | 11 | 1 | X | 1 | X00000000000000000000
1903/041 | 2 | 1 | 2 | XX | X | X | 100100000000000000000
2006/071 | X | X | 1 | 11 | 1 | X | X | 100000000000000000000
2106/071 | X | X | 1 | 11 | 1 | X | X | X00000000000000000000
2206/071 | 1 | 1 | X | 11 | 1 | X | X | 200000000000000000000
2306/07X | 1 | 2 | X | 11 | 1 | X | 2 | 100000000000000000000
2406/071 | 1 | 1 | X | 12 | 1 | X | 1 | 1 | 1 | 1 | 100000000001000000000
2508/091 | 1 | 1 | 1 | 11 | 1 | X | 2 | 200000000000000000000
2608/091 | 1 | 1 | 1 | 11 | 1 | 2 | 1 | 100000000000000000000
2708/092 | 1 | X | 1 | 1 | 11 | 1 | 1 | X | 1 | 100000000000000000000
2808/091 | 1 | 1 | 1 | X | 11 | 1 | 1 | X | 1 | X00000000000000000000
2908/09X | 1 | 2 | 1 | 2 | X1 | X | 1 | 1 | X | X | 2 | 200000000000000100000
3008/091 | X | 2 | 2 | 2 | 11 | 1 | 1 | X | X | 100000000000000000000
3110/111 | X | 1 | 1 | X | X1 | 1 | 1 | X | X | X00000000000000000000
3210/111 | X | 1 | 2 | 2 | 11 | 1 | 1 | X | X | 200000000000000000000
3310/11X | 1 | X | 1 | X | 1X | 1 | 2 | 1 | 2 | X | X | 100000000000001000000
3410/11X | X | X | 1 | 1 | 11 | 1 | 1 | X | 2 | X00000000000000000000
3510/111 | 1 | 1 | 1 | 2 | 1 | X | 1X | 1 | 2 | 1 | 2 | X | X | 100000000000001000000
3610/112 | X | 2 | X | 1 | 2 | 1 | XX | 1 | 2 | 1 | 2 | X | X | 100000000000001000000
3710/112 | 1 | X | 1 | 1 | 1 | 1 | 1X | 1 | 2 | 1 | 2 | X | X | 100000000000001000000
3811/121 | 1 | 1 | 1 | X | 1 | X | 11 | 1 | 1 | 1 | 2 | 1 | 2 | X00000000000000000000
3913/14X | 1 | 2 | 1 | 2 | X | X | 1X | 1 | 2 | 1 | 2 | X | X | 100000000000001000000
4013/141 | X | 2 | 2 | 2 | 1 | X | X1 | 1 | 1 | 1 | 2 | X | 1 | 100000000000000000000
4114/151 | X | 1 | 1 | X | X | 2 | 21 | 1 | 1 | 1 | 2 | X | 1 | X00000000000000000000
4214/151 | X | 1 | 2 | 2 | 1 | X | 11 | X | 2 | 2 | 2 | 1 | X | X | 200000000000000000100
4314/15X | 1 | X | 1 | X | 1 | 1 | X1 | 1 | 1 | 1 | 2 | X | X | 100000000000000000000
4414/15X | X | X | 1 | 1 | 1 | 1 | X1 | 1 | 1 | 1 | 2 | X | X | X00000000000000000000
4516/172 | X | 1 | 1 | 1 | 2 | X | X1 | 1 | 1 | 1 | 2 | X | X | 200000000000000000000
4616/172 | 1 | X | 1 | 1 | 1 | 1 | 1 | 21 | 1 | 1 | 2 | 1 | 2 | 1 | 2 | 200000000000000000000
4716/171 | 1 | 1 | 1 | X | 1 | X | 1 | 21 | 1 | 1 | 2 | 1 | 2 | X | 1 | 100000000000000000000
4817/08X | 1 | 2 | 1 | 2 | X | X | 1 | 11 | 1 | 1 | 2 | 1 | 2 | X | 1 | X00000000000000000000
4917/181 | X | 2 | 2 | 2 | 1 | X | X | 21 | 1 | 1 | 2 | 1 | 2 | X | 1 | 200000000000000000000
5017/181 | X | 1 | 1 | X | X | 2 | 2 | X1 | 1 | 1 | 2 | 1 | 2 | X | X | 100000000000000000000
5118/191 | X | 1 | 2 | 2 | 1 | X | 1 | 1X | 1 | 1 | 100010000000000000000
5218/19X | 1 | X | 1 | X | 1 | 1 | X | 11 | 1 | 1 | 2 | 1 | 2 | X | X | 200000000000000000000
5318/19X | X | X | 1 | 1 | 1 | 1 | X | 11 | 1 | 1 | 2 | 1 | 2 | X | 2 | 100000000000000000000
5419/202 | X | 1 | 1 | 1 | 2 | X | X | X1 | X | 1 | 2 | 2 | 100000000001000000000
5519/20X | 1 | X | X | 1 | 1 | 1 | 1 | 11 | 1 | 1 | 2 | 1 | 2 | X | 2 | 200000000000000000000
5619/201 | X | X | 1 | 2 | 1 | 2 | 1 | 11 | 1 | 1 | 2 | 1 | 2 | 2 | 1 | 100000000000000000000
5719/20X | 2 | X | 1 | 1 | X | 1 | 1 | 11 | 1 | 1 | 2 | 1 | 2 | 2 | 1 | X00000000000000000000
5819/201 | 1 | 1 | 1 | 1 | 1 | X | X | XX | 2 | X | 1 | 100010000000000000000
5919/201 | 2 | 1 | 2 | X | 1 | 1 | 2 | X1 | 1 | 1 | 1 | X | 1 | X | 1 | 200000000000000001000
60
61

VBA Code:
Sub FillFormlas_SUMPRODUCT()
   
           
      Sheets("Sumproduct").Select
      Range("E4:X59003").ClearContents
      Range("E4").Select
     

     
     Dim lngLastRow As Long
     lngLastRow = Cells(Rows.Count, "C").End(xlUp).Row
'-------------------------------------------------------------
    Application.ScreenUpdating = False
'-------------------------------------------------------------
   
     Range("E4:X" & lngLastRow).Formula = "=SUMPRODUCT(--($B$4:$B$5004=$C4),--($A$4:$A$5004=E$3))"
     Range("E5:X" & lngLastRow) = Range("E5:X" & lngLastRow).Value 'Convert Values

'-------------------------------------------------------------
    Application.ScreenUpdating = True
'-------------------------------------------------------------
End Sub

Thank you in advance

Regards,
Kishan
 

Attachments

  • SUMPRODUCT.png
    SUMPRODUCT.png
    96 KB · Views: 15
Try the following, adaptation of the code from post #2

VBA Code:
Sub Fill_Arrays_1()
  Dim a As Variant, b As Variant, c As Variant
  Dim i As Long, j As Long, lr As Long
  Dim dic As Object
  Dim llave As String
 
  Sheets("Sumproduct").Select
  Set dic = CreateObject("Scripting.Dictionary")
 
  lr = Range("A" & Rows.Count).End(3).Row
  'starting from column "E6"
  a = Range("A6:C" & lr).Value
  b = Range("E3:X3").Value
  c = Range("E6:X" & lr).Value
 
  For i = 1 To UBound(a, 1) Step 2
    llave = a(i, 1) & "|" & a(i, 2)
    dic(llave) = dic(llave) + 1
  Next
 
  For i = 1 To UBound(a, 1) Step 2
    For j = 1 To UBound(b, 2)
      llave = b(1, j) & "|" & a(i, 3)
      If dic.exists(llave) Then
        If c(i, j) = "" Or c(i, j) = 0 Then
          c(i, j) = dic(llave)
        End If
      Else
        If c(i, j) = "" Then
          c(i, j) = 0
        End If
      End If
    Next
  Next
 
  'starting from column "E6"
  Range("E6").Resize(UBound(c, 1), UBound(c, 2)).Value = c
End Sub
DanteAmor, I am in shock to try your new code adapted to new layout it has worked I have no words to express my happiness this is a eye-blink and time saver solution

I appreciate your determination in showing me I can do it! Thanking you for your perseverance, support! Multi times I can’t even begin to explain how much your help meant to me.

I wish you, Good Luck

Kind Regards,
Kishan :)
 
Upvote 0

Excel Facts

Did you know Excel offers Filter by Selection?
Add the AutoFilter icon to the Quick Access Toolbar. Select a cell containing Apple, click AutoFilter, and you will get all rows with Apple

Forum statistics

Threads
1,213,536
Messages
6,114,202
Members
448,554
Latest member
Gleisner2

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top