我有一个公式可以在另一张纸上搜索列标题,然后一旦找到它就会通过一些sumifs
. 我的数据大致如下:
1 8 10 11 12
Column E ... Column N ... Column O ... Column AB Column AC Column AD Column AE
Existing CCS data 100.00 100.00 120.00 150.00
列名上方的数字很重要,我用它们来指定与我的公式相关的列。现在,实际上只有少数几个单元对循环很重要。单元格 A1 具有我要终止的列的编号。单元格 B1 具有我要开始的列的编号。因此,如果我选择A1=8
and B1=1
,我希望下面的代码sumifs
通过搜索 column 开始运行1
,然后搜索 column 2
,一直到 column8
并将每个循环中的所有值加在一起并给我总数。以上表为例,如果我设置A1="12"
and B1="10"
,我希望它吐出370.00
。
我目前的公式是这样的:
=SUMIFS(INDEX('Program Data'!$A:$GA,0,MATCH(A1,'Data'!$1:$1,0)),'Data'!$N:$N,"CCS",
'Data'!$E:$E,"Existing")+SUMIFS(INDEX('Data'!$A:$GA,0,MATCH(A1,'Data'!$1:$1,0)),
'Data'!$N:$N,"CCS",'Data'!$E:$E,"Deep")
上面的公式只为我提供了包含 中的数字字符串的列的A1
总数,但我需要包含来自 的字符串的所有列的总数B1 -> A1
。
编辑
根据要求,这是我在此循环中的失败尝试。由于 B1 本质上始终是一个静态数字(意味着它将始终为 45 或 88 之类的),我想我可以创建一个循环,告诉它从 B1 的任何值开始,并根据需要创建公式并将其放入单元格中它。所以对于这个,B1=1=z...
Sub LoopingYTD()
Dim z As Integer: z = 1
Dim formulaString2 As String
Do Until z = Range("A1") + 1
If formulaString2 = "" Then
formulaString2 = "="
Else
formulaString2 = formulaString2 & " + "
End If
formulaString2 = formulaString2 + " SUMIFS(INDEX('Data'!A:GA,0,MATCH("
formulaString2 = formulaString2 & """*"" &
formulaString2 = formulaString2 & "z"&" ""
formulaString2 = formulaString2 & """*""" & ",'Data'!1:1,0)),"
formulaString2 = formulaString2 & "'Data'!$N:$N,”CCS”,”
formulaString2 = formulaString2 & “'Data'!$E:$E,”Existing”))"
formulaString2 = formulaString2 & "+ SUMIFS(INDEX('Data'!A:GA,0,MATCH("
formulaString2 = formulaString2 & """*"" &
formulaString2 = formulaString2 & "z"&" ""
formulaString2 = formulaString2 & """*""" & ",'Data'!1:1,0)),"
formulaString2 = formulaString2 & "'Data'!$N:$N,”CCS”,”
formulaString2 = formulaString2 & “Data'!$E:$E, ”Deep”))"
z = z + 1
Loop
Range("B20").Value = formulaString2
我不断收到“应用程序定义的或对象定义的错误”,但我不确定对此的补救措施是什么。
这是基于我之前提出的问题的建议。从那时起,我一直在尝试简化它,因为这有点乱,所以我只希望它搜索单个数字字符串。基本上运行链接中的代码,但不是一些基于多个单元格的长而复杂的字符串,我只想让它计数直到它达到 A1 中的值。