+ Reply to Thread
Results 1 to 7 of 7

Excel 2007 : excel if then macro help

  1. #1
    Registered User
    Join Date
    03-08-2010
    Location
    oregon, USA
    MS-Off Ver
    Excel 2007
    Posts
    3

    excel if then macro help

    I am wondering if there is an If then macro that can be used to convert a number in one cell to a predefined set number in another cell.
    I am working on a retail cost spreadsheet for a point of sales database.
    I have a pricing formula that goes:
    $2.00-$3.99 cost will be $9.99 markup
    $4.00-$4.99 cost will be $12.99 markup
    $5.00-$6.99 cost will be $17.99 markup
    and so on all the way to $200 cost.

    What I would like to do is put the actual cost in one cell and have a predefined If then with my pricing formula to set the retail markup in another adjacent cell.

    For example:
    saying C is cell A2-A1000 for example
    and R is cell B2-B21000

    cost = C
    retail = R

    If C =< 3.99
    Then R = 9.99
    If C =< 4.99
    Then R = 12.99

    etc etc.

    I don't know how in excel to associate cells into VBA any help on how to set this up or help would be great
    Last edited by aarons; 03-08-2010 at 08:07 PM. Reason: solved

  2. #2
    Forum Expert teylyn's Avatar
    Join Date
    10-28-2008
    Location
    New Zealand
    MS-Off Ver
    Excel 365 Insider Fast
    Posts
    11,372

    Re: excel if then macro help

    Hi,

    is there a particular reason you want to do this with VBA instead of a worksheet formula?

    You can set up your markup structure in a part of the workbook and then use a Lookup formula to lookup the correct markup based on the data in column A.

    Heck of a lot easier to maintain than a macro.

  3. #3
    Forum Expert JBeaucaire's Avatar
    Join Date
    03-21-2004
    Location
    Bakersfield, CA
    MS-Off Ver
    2010, 2016, Office 365
    Posts
    33,492

    Re: excel if then macro help

    Why a macro? A simple lookup table will do this job in a formula.

    Please Login or Register  to view this content.
    With the table in columns D and E, put this formula in B2 then copy down:

    =VLOOKUP($A2, $D$2:$E$100, 2, FALSE)
    _________________
    Microsoft MVP 2010 - Excel
    Visit: Jerry Beaucaire's Excel Files & Macros

    If you've been given good help, use the icon below to give reputation feedback, it is appreciated.
    Always put your code between code tags. [CODE] your code here [/CODE]

    ?None of us is as good as all of us? - Ray Kroc
    ?Actually, I *am* a rocket scientist.? - JB (little ones count!)

  4. #4
    Registered User
    Join Date
    03-08-2010
    Location
    oregon, USA
    MS-Off Ver
    Excel 2007
    Posts
    3

    Re: excel if then macro help

    Quote Originally Posted by JBeaucaire View Post
    Why a macro? A simple lookup table will do this job in a formula.

    Please Login or Register  to view this content.
    With the table in columns D and E, put this formula in B2 then copy down:

    =VLOOKUP($A2, $D$2:$E$100, 2, FALSE)
    Sorry I am not too familiar with formulas as my background is more in coding. Help is very much appreciated.

    The problem I have when I set it up as the example above is:

    I have a cost of 7.49 the lookup seems to only lookup the defined number in the vcode column.
    It works great if the cost is 7.00 but not if it is 7.01-7.99.
    That is why I thought Macro instead since my costs can range greatly.

    Since an If/Then can easily grasp the range with an (=)equal to or (<) less than as my example I posted above.
    Is there a way to utilize the VLOOKUP to read a RANGE such as my cost variants from for example 7.01 to 7.99?

    In your example above you used 1.50 as an example cost when I did a simple test using the table you posted above it gives me a #NA using 0, 4, 5 etc as you used above.

    Thanks for the help so far I realy appreciate it. Any continued help would be awesome!!

  5. #5
    Forum Expert teylyn's Avatar
    Join Date
    10-28-2008
    Location
    New Zealand
    MS-Off Ver
    Excel 365 Insider Fast
    Posts
    11,372

    Re: excel if then macro help

    You need to change the last argument of the VLookup to TRUE


    =VLOOKUP($A2,$D$2:$E$100,2,TRUE)

    then the formula will return the next match that is smaller than or equal to the lookup value

    hth

  6. #6
    Registered User
    Join Date
    03-08-2010
    Location
    oregon, USA
    MS-Off Ver
    Excel 2007
    Posts
    3

    Re: excel if then macro help

    Quote Originally Posted by teylyn View Post
    You need to change the last argument of the VLookup to TRUE


    =VLOOKUP($A2,$D$2:$E$100,2,TRUE)

    then the formula will return the next match that is smaller than or equal to the lookup value

    hth
    LOL thanks so much I just figured that out as you posted thanks so so much Teylyn you both are awesome for the help!!!

  7. #7
    Forum Expert JBeaucaire's Avatar
    Join Date
    03-21-2004
    Location
    Bakersfield, CA
    MS-Off Ver
    2010, 2016, Office 365
    Posts
    33,492

    Re: excel if then macro help

    My bad....how embarrassing is that? (bang head against wall here)

    ========
    If that takes care of your need, please click EDIT in your original post, click GO ADVANCED and set the PREFIX box to SOLVED.

+ Reply to Thread

Thread Information

Users Browsing this Thread

There are currently 1 users browsing this thread. (0 members and 1 guests)

Bookmarks

Posting Permissions

  • You may not post new threads
  • You may not post replies
  • You may not post attachments
  • You may not edit your posts

Search Engine Friendly URLs by vBSEO 3.6.0 RC 1