VBA 多条件求和

一列时间,一列数量,一列名称,在A,B,C三列,是一个动态区域,现在求满足时间与名称的数量和,用VBA编的程序必须是动态区域。... 一列时间,一列数量,一列名称,在A,B,C三列,是一个动态区域,现在求满足时间与名称的数量和,用VBA编的程序必须是动态区域。 展开
 我来答
knifefox
2010-09-04 · TA获得超过1.6万个赞
知道大有可为答主
回答量:1329
采纳率:76%
帮助的人:741万
展开全部
Sub test()
Dim oDic As Object
Dim i As Long
Dim Dsum
Dim Arr
Arr = Range("A1:C" & [A65536].End(xlUp).Row)
Set oDic = CreateObject("Scripting.Dictionary")
With oDic
For i = 1 To UBound(Arr)
oDic(Format(Arr(i, 1), "yy-m-d") & "@@" & Arr(i, 2)) = oDic(Format(Arr(i, 1), "yy-m-d") & "@@" & Arr(i, 2)) + Arr(i, 3)
Next
End With
Dsum = oDic(Format("2010-8-5", "yy-m-d") & "@@" & "A") '"2010-8-5"这个是你求和的日期,"A"是名称根据需要自己设置
End Sub

参考资料: office助

创作者wv1DQrrmot
2019-11-09 · TA获得超过3万个赞
知道大有可为答主
回答量:1.2万
采纳率:30%
帮助的人:775万
展开全部
目测你所需要的功能,暂时还不需要vba(如确实需要请注明)
函数
sumifs()
如果是大量数据需要做统计分析的话,可以试试透视表
选中表格1数据区,插入透视表,
行选中A
列选择B
值选择C,试试
------------------------
如果非要vba,还是借助excel内置函数即可,vba调用内置函数
Application.WorksheetFunction.sumifs()
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式