ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

搜索
EH技术汇-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 效率神器,一键搞定繁琐工作
HR薪酬管理数字化实战 Excel 2021函数公式学习大典 Excel数据透视表实战秘技 打造核心竞争力的职场宝典
让更多数据处理,一键完成 数据工作者的案头书 免费直播课集锦 ExcelHome出品 - VBA代码宝免费下载
用ChatGPT与VBA一键搞定Excel WPS表格从入门到精通 Excel VBA经典代码实践指南
查看: 1579|回复: 13

[求助] 求助VBA去重复多条件汇总

[复制链接]

TA的精华主题

TA的得分主题

发表于 2023-1-29 22:15 | 显示全部楼层 |阅读模式
根据工作表"送货单数据表"的C列到F列,4列数据除去重复。然后将工I列的数量根据U列的出入库类别,分别汇总入库数量和汇总出库数量。并增加一列库存数量:等于入库减出库。也就是要工作表"库存表"这个效果。其实这个也就是透视表的功能,不过用透视表数据多了,运行非常慢。所以求助vba代码实现。

VBA去重复多条件汇总.rar (16.36 KB, 下载次数: 17)

TA的精华主题

TA的得分主题

发表于 2023-1-30 07:55 | 显示全部楼层
本帖最后由 chzsh 于 2023-1-30 17:26 编辑

VBA去重复多条件汇总

TA的精华主题

TA的得分主题

发表于 2023-1-30 07:56 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
本帖最后由 chzsh 于 2023-1-30 16:34 编辑

VBA去重复多条件汇总

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2023-1-30 08:11 | 显示全部楼层
Sub 按钮1_Click()
    Set d = CreateObject("scripting.dictionary")
    Sheets("送货单数据表").[a1] = 1
    arr = Sheets("送货单数据表").UsedRange
    r = 0
    For j = 4 To UBound(arr)
        str1 = arr(j, 3) & arr(j, 4) & arr(j, 5) & arr(j, 6)
        If Not d.exists(str1) Then
            r = r + 1
            d(str1) = r
            x = 0
            For Each i In Array(3, 4, 5, 7, 6)
                x = x + 1
                arr(r, x) = arr(j, i)
            Next i
            arr(j, 6) = 0
            arr(j, 7) = 0
            arr(j, 8) = 0
        End If
        If arr(j, 21) = "出库" Then
            arr(d(str1), 6) = Val(arr(d(str1), 6)) + Val(arr(j, 9))
            
        End If
        arr(d(str1), 8) = Val(arr(d(str1), 8)) + Val(arr(j, 9))
        arr(d(str1), 7) = Val(arr(d(str1), 8)) - Val(arr(d(str1), 6))
    Next j
    [a8].Resize(r, 8) = arr
    Sheets("送货单数据表").[a1] = ""
End Sub

评分

1

查看全部评分

TA的精华主题

TA的得分主题

发表于 2023-1-30 08:13 | 显示全部楼层
供参考。。。。。

材料汇总表.zip

23.95 KB, 下载次数: 17

TA的精华主题

TA的得分主题

发表于 2023-1-30 08:13 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册

TA的精华主题

TA的得分主题

发表于 2023-1-30 10:23 | 显示全部楼层
Sub 分类汇总()
Application.ScreenUpdating = False
Dim ar As Variant
Dim d As Object
Set d = CreateObject("scripting.dictionary")
With Sheets("送货单数据表")
    r = .Cells(Rows.Count, 3).End(xlUp).Row
    If r < 4 Then MsgBox "送货单数据表为空!": End
    ar = .Range("c3:u" & r)
End With
Dim br()
ReDim br(1 To UBound(ar), 1 To 8)
For i = 2 To UBound(ar)
    If Trim(ar(i, 1)) <> "" And Trim(ar(i, 2)) <> "" And Trim(ar(i, 3)) <> "" And Trim(ar(i, 4)) <> "" Then
        zd = Trim(ar(i, 1)) & "|" & Trim(ar(i, 2)) & "|" & Trim(ar(i, 3)) & "|" & Trim(ar(i, 4))
        t = d(zd)
        If t = "" Then
            k = k + 1
            d(zd) = k
            t = k
            For j = 1 To 5
                br(k, j) = ar(i, j)
            Next j
        End If
        If VBA.Trim(ar(i, 19)) = "入库" Then
            br(t, 6) = br(t, 6) + ar(i, 9)
        Else
            br(t, 7) = br(t, 7) + ar(i, 9)
        End If
        br(t, 8) = br(t, 6) - br(t, 7)
    End If
Next i
With Sheets("库存表")
    .[a1].CurrentRegion.Offset(2).Borders.LineStyle = 0
    .[a1].CurrentRegion.Offset(2) = Empty
    .[a3].Resize(k, UBound(br, 2)) = br
    .[a3].Resize(k, UBound(br, 2)).Borders.LineStyle = 1
End With
MsgBox "ok!"
End Sub

TA的精华主题

TA的得分主题

发表于 2023-1-30 10:23 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2023-1-30 10:24 | 显示全部楼层
VBA去重复多条件汇总.rar (25.15 KB, 下载次数: 12)

评分

1

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2023-1-30 12:31 | 显示全部楼层
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

手机版|关于我们|联系我们|ExcelHome

GMT+8, 2024-9-27 19:39 , Processed in 0.052027 second(s), 16 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

沪公网安备 31011702000001号 沪ICP备11019229号-2

本论坛言论纯属发表者个人意见,任何违反国家相关法律的言论,本站将协助国家相关部门追究发言者责任!     本站特聘法律顾问:李志群律师

快速回复 返回顶部 返回列表