Solved

Problem with nested IF loop in Excel

Posted on 2011-02-15
6
404 Views
Last Modified: 2012-05-11
Hi all

I am learning Excel and I can sometimes apply what I have learned at work.

Here is my problem:
I wrote a formula with several loops and was told by Excel that the formula is too long. I later read that there cannot be more than six IFs in a formula.

Please let me explain what I would like to accomplish:

The spreadsheet is a simple inventory spreadsheet.The formula in the last sheet will be used in the original inventory file.

There is one sheet for each month, the last sheet being the annual overview.
The last sheet should display the beginning inventory: The item might be added in January or sometime during the year.
The items will not be added by me to the spreadsheet. There might be empty rows and the items might not be ordered. Short: It will look like a mess.
There might be as many as 200 rows.

This is my idea:

1

I went to the sheet "Inventory"

2

In cell C2 I set a formula with IF() and LOOKUP() to search for the Products (A and B) in the month of January

3

I used ISNA() to check for a match.

4

If there is a match, return the value in column C (the inital stock)

5

Otherwise, go to the next month (February, March etc).and do the same search
Is there any other way to solve this problem? I read that I could use SUMPRODUCT() but that did not work. If this cannot be done with a formula, would it be possible to write a custom function? I have written basic VBA code before but I have never custom functions.

I really appreciate your help as I can learn and have learned new ways to write my formulas.

Massimo

Untitled-1.gif
Inventory-Question.xls
0
Comment
Question by:mscola
  • 3
  • 2
6 Comments
 
LVL 24

Expert Comment

by:StephenJR
Comment Utility
One could write some vba to run through a list on the inventory sheet and find the first entry in the other sheets for each item. Does that sound useful? Btw Excel 2007 allows many more levels of nested formulae.
0
 
LVL 24

Accepted Solution

by:
StephenJR earned 250 total points
Comment Utility
Perhaps this custom function will help? So you can type, e.g =BegInv(A2,B2) in C2 of inventory sheet. Worked for your example file.
Function BegInv(vProd As Variant, vDesc As Variant) As Variant
  
Dim rFind As Range, ws As Worksheet, sAddr As String

With Sheets("Inventory")
    For Each ws In Worksheets
        If ws.Name <> "Inventory" Then
            Set rFind = ws.Columns(1).Find(What:=vProd, After:=ws.Range("A1"), _
                                           LookAt:=xlWhole, SearchDirection:=xlNext, _
                                           MatchCase:=False, SearchFormat:=False)
            If Not rFind Is Nothing Then
                sAddr = rFind.Address
                Do
                    If rFind.Offset(, 1) = vDesc Then
                        BegInv = rFind.Offset(, 2)
                        Exit For
                    Else
                        Set rFind = ws.Columns(1).Find(What:=vProd, After:=rFind)
                    End If
                Loop While rFind.Address <> sAddr
            End If
        End If
    Next ws
End With
     
End Function

Open in new window

0
 
LVL 24

Expert Comment

by:StephenJR
Comment Utility
Slight refinement, change line 16 to
Exit Function

Open in new window

and add at line 25:
BegInv=""

Open in new window

0
How to run any project with ease

Manage projects of all sizes how you want. Great for personal to-do lists, project milestones, team priorities and launch plans.
- Combine task lists, docs, spreadsheets, and chat in one
- View and edit from mobile/offline
- Cut down on emails

 
LVL 37

Assisted Solution

by:TommySzalapski
TommySzalapski earned 250 total points
Comment Utility
I recommend the making a summary of each month on the inventory sheet. Then you just need to find the first non-zero month. You can hide the month cells if you wish. The formula would look like this
=INDEX(C2:H2,MATCH(TRUE,C2:H2>0,0))
Note: It's an array formula so you need to hit ctrl+shift+enter when entering it.

Then I would do the following to speed it up and make it more robust
1: Use SUMPRODUCT to find the counts for each month instead of lookup(2/...) it's much much faster. It would look something like this
=SUMPRODUCT((January!$A$2:$A$300)=$A2)*(January!$B$2:$B$300)=$B2)*January!$C$2:$C$300)
2: To do all the months without having to retype the formula, just use INDIRECT and the column header
=SUMPRODUCT((INDIRECT(C$1&"!$A$2:$A$300)=$A2)*(INDIRECT(C$1&"!$B$2:$B$300)=$B2)*INDIRECT(C$1&"!$C$2:$C$300))
3: Wait, what if there are more than 300? Put a =counta(A:A) somewhere (like J1) and use it
=SUMPRODUCT((INDIRECT(C$1&"!$A$2:$A$"&$J$1)=$A2)*(INDIRECT(C$1&"!$B$2:$B$"&$J$1)=$B2)*INDIRECT(C$1&"!$C$2:$C$"&$J$1))

Hide any columns you would like

Posting example file.
Inventory-Q.xls
0
 
LVL 37

Expert Comment

by:TommySzalapski
Comment Utility
Note that even though I added columns, my file is 30% smaller than yours. This may matter if the sheets get large. The computation will also be a lot faster and you can add months simply by dragging the formulas over.
0
 

Author Closing Comment

by:mscola
Comment Utility
fantastic
0

Featured Post

Highfive Gives IT Their Time Back

Highfive is so simple that setting up every meeting room takes just minutes and every employee will be able to start or join a call from any room with ease. Never be called into a meeting just to get it started again. This is how video conferencing should work!

Join & Write a Comment

Drop Down List with Unique/Distinct Values (Part II - ComboBox or ListBox and Data Validation List Bonus!) David Miller (dlmille) Intro This article focuses on delivering unique, sorted lists to list objects (e.g., ComboBox, ListBox) and Dat…
Introduction This Article is a follow-up to my Mappit! Addin Article (http://www.experts-exchange.com/A_2613.html), it was inspired by an email posting I made to EUSPRIG (http://www.eusprig.org/index.htm), I will briefly cover: 1) An overvie…
Viewers will learn the basics of slicers and timelines for both PivotTables and standard Excel tables in Excel 2013.
This Micro Tutorial will demonstrate on a Mac how to change the sort order for chart legend values and decrpyt the intimidating chart menu.

762 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

10 Experts available now in Live!

Get 1:1 Help Now