我正在尝试使用VBA在单元格位置查找值,我在询问之前搜索了谷歌和所有的stackoverflow,因为我似乎无法让它工作。
以下是我尝试使用的代码,请注意,budgetcode引用包含第一列中的一个代码的单元格,mo引用包含数字(1-12)或包含短代码的单元格(ytd) ,1qtr,2qtr,3qtr)。例如,我想在二月份(2)拉出CAD-NS,我应该得到5666.40。
Function eBudgetl(budgetcode As String, mo As String)
eBudgetl = Application.WorksheetFunction.Index(Range("Budget!G1:X5000"), _
Application.WorksheetFunction.Match(budgetcode, Range("Budget!B1:B5000"), 0), _
Application.WorksheetFunction.Match(mo, Range("Budget!G1:X1"), 0))
End Function
以下是我希望查找的数据的一部分:
1 2 3 4
CAD-NS I Net Sales 5264.0 5666.4 5614.9 5966.6
COSMAT E Material 6207.5 3660.0 3661.9 3560.9
COSDL E Direct Labor 610.4 105.3 167.1 123.6
CAD-MOIL E Indirect Labor 671.2 163.4 181.6 161.7
CAD-MOSAL E Salary Overhead 601.0 106.0 101.0 101.0
以下是单元格中的代码,但我需要在VBA中进行操作。 (我需要在vba中执行的原因有时候,预算代码将包含由逗号分隔的2个引用,我将使用vba将它们分开并独立查看每个引用。)
=INDEX(Budget!$G$1:$X$5000,MATCH($F12,Budget!$B$1:$B$5000,0),MATCH(AN$1,Budget!$G$1:$X$1,0))
我非常感谢任何帮助,我已经在这3天了。
谢谢,
诺
答案 0 :(得分:4)
问题是Function
参数类型。
当您使用mo
=单元格AN1
调用包含数字 1
的函数时,函数类型会将其强制转换为 String < / em> "1"
,在Budget!$G$1:$X$1
范围内不存在,因为它们也是数字。
解决方案是使用Variant
作为函数参数类型。
为了使这种类型的错误更容易调试,尽量不要在一行代码中做太多。将该行拆分为2 x Match
个函数和Index
,可以让您看到第二个匹配返回错误。
其他几点:
eBudgetl
的调用不会在数据发生任何变化时自动重新计算。Application
对象的版本为Index
和Match
,因此不需要WorksheetFunction
次来电用于演示的重构版本:
Function eBudgetl(rData As Range, rBudCode As Range, rMo As Range, budgetcode As Variant, mo As Variant)
Dim rw As Variant
Dim col As Variant
With Application
col = .Match(budgetcode, rBudCode, 0)
rw = .Match(mo, rMo, 0)
eBudgetl = .Index(rData, col, rw)
End With
End Function
被称为
=eBudgetl(Budget!$G$1:$X$5000,Budget!$B$1:$B$5000,Budget!$G$1:$X$1,$F12,AN$1)