We help IT Professionals succeed at work.

# VBA:  Getting Range Averages w/o #DIV/0!

on
462 Views
Hi,
In the VBE, I'm looping through a spreadsheet (that I can't modify) to get averages. Some ranges I'm getting averages for consist of all blank cells--so the result in those cases shows "#DIV/0!". What's the best way to make VBE give those ranges a "0" value, rather than a "#DIV/0!" value?

Here's the code format:

Sub RangeAvg()
Dim i as Integer, ShadeAvg as Integer, JanArray

For i = 3 To 57 Step 2
ShadeAvg = Application.Average(Range(Cells(16, i), Cells(46, i + 1)))
JanArray((i - 1) / 2) = ShadeAvg
Next i

Range("d4:ae4").Value = JanArray()

End Sub

Thanks!
-Michael
Comment
Watch Question

## View Solution Only

CERTIFIED EXPERT
Top Expert 2008

Commented:
Try:

Sub RangeAvg()
Dim i as Integer, ShadeAvg as Integer
Dim JanArray(1 To 28) As Double

For i = 3 To 57 Step 2
ShadeAvg = Application.Average(Range(Cells(16, i), Cells(46, i + 1)))
JanArray((i - 1) \ 2) = ShadeAvg
Next i

Range("d4:ae4").Value = JanArray

End Sub

Kevin
CERTIFIED EXPERT
Top Expert 2008
Commented:
Unlock this solution and get a sample of our free trial.
(No credit card required)

Commented:
Kevin,
You are the man.
Thank you!
-Michael

Gain unlimited access to on-demand training courses with an Experts Exchange subscription.

###### Why Experts Exchange?

Experts Exchange always has the answer, or at the least points me in the correct direction! It is like having another employee that is extremely experienced.

Jim Murphy
Programmer at Smart IT Solutions

Deciding to stick with EE.

Mohamed Asif

Being involved with EE helped me to grow personally and professionally.

Carl Webster
CTP, Sr Infrastructure Consultant
###### Did You Know?

We've partnered with two important charities to provide clean water and computer science education to those who need it most. READ MORE

Connect with Certified Experts to gain insight and support on specific technology challenges including:

• Troubleshooting
• Research
• Professional Opinions
Unlock the solution to this question.