Solved

Want to find an Excel formula to lookup the value to the right of the next smallest date

Posted on 2012-03-30
12
277 Views
Last Modified: 2012-04-05
I'm trying to create a formula similar to a vlookup that finds the next smallest occurance of a date and selects the value in the column to the right of the date found. I have attached an excel spreadsheet example to help explain. I'm using Excel 2010 with Windows 7.

Thanks!

Phil
Excel-Lookup-Example.xlsm
0
Comment
Question by:pabrann
  • 7
  • 3
12 Comments
 
LVL 81

Assisted Solution

by:zorvek (Kevin Jones)
zorvek (Kevin Jones) earned 250 total points
ID: 37789588
=VLOOKUP(MAX(B:B)-1,B:C,2,TRUE)

Kevin
0
 
LVL 80

Assisted Solution

by:byundt
byundt earned 250 total points
ID: 37789685
Phil,
It looks as though you want to return the previous trading day's closing price. If so, you might modify Kevin's formula to:
=VLOOKUP(B11-1,B:C,2)                         put this formula in row 11

Brad
0
 

Author Comment

by:pabrann
ID: 37789726
Thanks Kevin, Your formula worked! Awesome. I did have a circular reference error so I inserted the row coordinates in the max(B:B) and that seemed to fix it.
0
 

Author Comment

by:pabrann
ID: 37789767
Hi Brad,

Sorry, I didn't see that you had commented before I accepted Kevin's suggestion.

Your formula works also. Is there any way I can give you points for this as well?

Thanks so much...

Phil
0
 
LVL 80

Expert Comment

by:byundt
ID: 37789780
Phil,
While the two formulas return the same result if you paste them in one cell only, they give different results if you copy them down a long column of data. Kevin's formula always returns the same answer. Mine will return a different answer depending on the date in column B.

Which behavior do you need? If the formula will only be applied in one cell, then Kevin posted first and deserves all the points. But if you do need different answers depending on the date in column B, then a split would be appropriate. I'd be glad to reopen the question in such a situation.

Brad
0
How your wiki can always stay up-to-date

Quip doubles as a “living” wiki and a project management tool that evolves with your organization. As you finish projects in Quip, the work remains, easily accessible to all team members, new and old.
- Increase transparency
- Onboard new hires faster
- Access from mobile/offline

 

Author Comment

by:pabrann
ID: 37791045
Hi Brad,

I attached a copy of the actual spreadsheet involving this formula. It starts in range("AE3") and copied down to the last row. The formula is a modified version of Kevin's formula which yours may be able to replace. I have had some circular reference issues and also Excel has crashed a few times when I had too many records and tried to delete them.

This spreadsheet is a sheet used to backtest a daytrading system that I created. The system trades a maximum of three symbols per day and the number of shares is calculated with the formula in question (selecting the previous days portfolio balance, dividing by the number of maximum trades, and then dividing by the trigger price per share).

I will try your formula and see how it works. If you have any questions, please let me know.

Thanks so much, Phil
0
 

Author Comment

by:pabrann
ID: 37791050
Sorry, I think I forgot to actually attach the file.
PBDT-Test-20120331g.zip
0
 
LVL 80

Expert Comment

by:byundt
ID: 37791112
Phil,
Because your dates in column AO are already sorted in ascending order, there is no need to take the MAX of an ever-growing range. You can therefore simplify the formula in cell AE3 to either of:
=IF(AD3>0,ROUND(VLOOKUP(AO3-1,AO:AP,2)/AJ$1/AD3,0),0)                   'TRUE is the default value of fourth parameter in VLOOKUP
=IF(AD3>0,ROUND(VLOOKUP(AO3-1,AO:AP,2,TRUE)/AJ$1/AD3,0),0)

I tested column AO to make sure that it was arranged in ascending order--it is. I also tested the suggested formula to make sure it returned the same answer as what you are using--it does.

Brad
0
 

Accepted Solution

by:
pabrann earned 0 total points
ID: 37791146
Brad,

Thanks so much for the clarification. I appreciate your expertise and am very satisified with these solutions. If you want to reopen the case and share points, I will be happy to do so.

Thanks again!

Phil
0
 

Author Comment

by:pabrann
ID: 37791247
A special thanks to you Brad for your expert clarifications and extra effort!
0
 

Author Closing Comment

by:pabrann
ID: 37810081
Multiple possibilities and they all work. Thanks so much!

Phil
0

Featured Post

Threat Intelligence Starter Resources

Integrating threat intelligence can be challenging, and not all companies are ready. These resources can help you build awareness and prepare for defense.

Join & Write a Comment

Introduction While answering a recent question (http:/Q_27311462.html), I created an alternative function to the Excel Concatenate() function that you might find useful.  I tested several solutions and share the results in this article as well as t…
This tutorial explains how to create a series of drop-down lists that are dependent upon prior selections to guide (“force”) the user to make the correct selection and reduce data errors within Microsoft Excel. Excel 2010 was used for this tutorial;…
Graphs within dashboards are meant to be dynamic, representing data from a period of time that will change each time the dashboard is updated with new data. Rather than update each graph to point to a different set within a static set of data, t…
This Micro Tutorial will demonstrate on a Mac how to change the sort order for chart legend values and decrpyt the intimidating chart menu.

743 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

14 Experts available now in Live!

Get 1:1 Help Now