公式中的动态列索引名称错误
我正在尝试通过使用 Vlookup 填充列来计算从图纸计划到图纸结果的组件数量,具有:
Count_col: 是工作表中的总列PlanLast_col: 是工作表中的总列Result(在添加列需求之前)
工作表结果
| 材料 | 成分 | 需求W1 | 需求 W2 |
|---|---|---|---|
| ABCD1000 | NC200 | #姓名? | #姓名? |
回答
i+1inside""表现得像一个字符串而不是一个变量。尝试这个。
ActiveCell.FormulaR1C1 = "=VLOOKUP(RC1,Plan!C1:C15," & i + 1 & ",0)"
也避免使用.Select. 你的代码可以写成
Cells(1, i + last_col).Offset(1, 0).FormulaR1C1 = _
"=VLOOKUP(RC1,Plan!C1:C15," & i + 1 & ",0)"
推荐阅读:如何避免在Excel VBA中使用Select
您也正在混合R1C1和A1引用风格。我建议使用其中之一。一个简单的谷歌搜索R1C1 vs A1 style将解释它们是什么。
在R1C1,Plan!C1:C15需要写成Plan!R1C3:R15C3。所以你的最终代码是
Cells(1, i + last_col).Offset(1, 0).FormulaR1C1 = _
"=VLOOKUP(RC1,Plan!R1C3:R15C3," & i + 1 & ",0)"