VBA Vlookup

superfb

Active Member
Joined
Oct 5, 2011
Messages
255
Office Version
  1. 2007
Platform
  1. Windows
Hi

i am currently learning VBA, and something that i thought should be easy to execute is proving to be a pain.....



Sub TestVlookup()


Dim Product As Variant
Dim Price As Double


Product = InputBox("What code are you looking for?")


Worksheets("Database").Activate


Price = WorksheetFunction.VLookup(Product, Range("Price"), 2, False)


MsgBox ("The cost of the product" & Product & " is" & Price)


Database sheet:

[TABLE="width: 128"]
<colgroup><col width="64" span="2" style="width:48pt"> </colgroup><tbody>[TR]
[TD="width: 64"]Product[/TD]
[TD="width: 64"]Price[/TD]
[/TR]
[TR]
[TD="align: right"]23[/TD]
[TD="align: right"]1.99[/TD]
[/TR]
[TR]
[TD="align: right"]24[/TD]
[TD="align: right"]25.64[/TD]
[/TR]
[TR]
[TD="align: right"]25[/TD]
[TD="align: right"]13.98[/TD]
[/TR]
[TR]
[TD="align: right"]26[/TD]
[TD="align: right"]11[/TD]
[/TR]
[TR]
[TD="align: right"]27[/TD]
[TD="align: right"]14.79
[/TD]
[/TR]
</tbody>[/TABLE]



I keep getting a 1004 error......Which is being caused by the vlookup- i have defined the variables and labeles the data sources (name range) as accordingly, but unable to figure out what is going on?
 

Excel Facts

Return population for a City
If you have a list of cities in A2:A100, use Data, Geography. Then =A2.Population and copy down.
How is the named range Price defined? It should be the columns containing both Product and Price (i.e., something like =DatabaseSheet!$A:$B)

Also, Product as Variant may be an issue if it is typed as String after the user enters a value, and you are looking up numbers. Try changing Product from Variant to Long, or changing your code to

Code:
[COLOR=#333333]Price = WorksheetFunction.VLookup([/COLOR][COLOR=#ff0000]CLng([/COLOR][COLOR=#333333]Product[/COLOR][COLOR=#ff0000])[/COLOR][COLOR=#333333], Range("Price"), 2, False)[/COLOR]

I have not experimented to replicate your issue but those are the thing I would try.
 
Upvote 0
Try
Code:
Sub TestVlookup()
Dim Product As Variant
Dim Price As Variant

Product = InputBox("What code are you looking for?")

Worksheets("Database").Activate

Price = Application.vlookup(CLng(Product), Range("Price"), 2, False)
If Not IsError(Price) Then
   MsgBox ("The cost of the product" & Product & " is" & Price)
End If
End Sub
It's better to Use Application rather then WorksheetFunction as you can test for an error rather than the code crashing
 
Last edited:
Upvote 0
How is the named range Price defined? It should be the columns containing both Product and Price (i.e., something like =DatabaseSheet!$A:$B)

Also, Product as Variant may be an issue if it is typed as String after the user enters a value, and you are looking up numbers. Try changing Product from Variant to Long, or changing your code to

Code:
[COLOR=#333333]Price = WorksheetFunction.VLookup([/COLOR][COLOR=#ff0000]CLng([/COLOR][COLOR=#333333]Product[/COLOR][COLOR=#ff0000])[/COLOR][COLOR=#333333], Range("Price"), 2, False)[/COLOR]

I have not experimented to replicate your issue but those are the thing I would try.

Price is defined as:

=Database!$A$2:$B$6

I have changed this to =Database!$A:$B

And changed Product from Variant to Long and now it seems to be working! Thank you

What does the function Clng do?
 
Upvote 0
Try
Code:
Sub TestVlookup()
Dim Product As Variant
Dim Price As Variant

Product = InputBox("What code are you looking for?")

Worksheets("Database").Activate

Price = Application.vlookup(CLng(Product), Range("Price"), 2, False)
If Not IsError(Price) Then
   MsgBox ("The cost of the product" & Product & " is" & Price)
End If
End Sub
It's better to Use Application rather then WorksheetFunction as you can test for an error rather than the code crashing

Thank you for your input - however if i type in 5000 i get a run time error?
 
Upvote 0
What is the error message & what line is highlighted when you click debug?

CLng converts a string value to a number.
 
Upvote 0
What is the error message & what line is highlighted when you click debug?

CLng converts a string value to a number.


Run time error 13

this appears because i type a huge number like 5000, which isnt in the database....
 
Upvote 0
You shouldn't be getting an error if the value is not in the database.
Have you changed the code I supplied?
Also what line of code gives the error?
 
Upvote 0
You shouldn't be getting an error if the value is not in the database.
Have you changed the code I supplied?
Also what line of code gives the error?

Sub TestVlookup()


Dim Products As Long
Dim Prices As Double


Products = InputBox("What code are you looking for?")




Worksheets("Database").Activate


Prices = Application.VLookup(CLng(Products), Range("Price"), 2, False)
If Not IsError(Price) Then
MsgBox ("The cost of the product " & Products & " is" & " £" & Prices)
Else
MsgBox ("Not in Database")
End If



i believe if i put in a large number the error arises from the If formula
 
Upvote 0

Forum statistics

Threads
1,225,053
Messages
6,182,581
Members
453,126
Latest member
NigelExcel

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