Excel精英培训网

 找回密码
 注册
数据透视表40+个常用小技巧,让你一次学会!
查看: 2479|回复: 5

[已解决]dsmch老师,有空帮我看看,谢谢。

[复制链接]
发表于 2014-4-22 19:07 | 显示全部楼层 |阅读模式
红色底纹的工作表中,明细表的E列,计件工资,是由总工序表+装模=计件工资,我想用VBA实现SUMIF函数功能的求和,因为总工序表中,已设置了VBA更新,如果明细表中用SUMIF函数公式,那么总工序表更新反映变慢,可否帮我解决,谢谢。
最佳答案
2014-4-22 20:42
刷新的同时填充明细表数据

试改.zip

325.33 KB, 下载次数: 3

发表于 2014-4-22 19:43 | 显示全部楼层
模拟两人以上结果,方便用数组测试。
回复

使用道具 举报

 楼主| 发表于 2014-4-22 19:59 | 显示全部楼层
dsmch 发表于 2014-4-22 19:43
模拟两人以上结果,方便用数组测试。

附件已修改,主要是想用VBA实现满足条件求和,明细表的E列。

试改.zip

326.51 KB, 下载次数: 6

回复

使用道具 举报

发表于 2014-4-22 20:40 | 显示全部楼层
  1. Sub Macro1()
  2. On Error Resume Next
  3. Dim arr, brr, crr(1 To 16, 1 To 8), d
  4. Dim n&, k%, j&, i&, s&, ar, br, cr
  5. Set d = CreateObject("scripting.dictionary")
  6. br = Sheets("装模").Range("a1").CurrentRegion
  7. cr = Sheets("明细表").Range("b5:b" & Sheets("明细表").Range("b65536").End(xlUp).Row)
  8. Range("a3:h65536").ClearContents
  9. n = 3
  10. For k = 1 To 2
  11.     arr = Sheets(k).UsedRange
  12.     For i = 2 To UBound(arr)
  13.         If InStr(arr(i, 1), "对应单号") And Len(arr(i, 1)) > 5 Then
  14.             brr = Sheets(k).Cells(i, 1).Resize(16, 8)
  15.             y = Val(brr(1, 6)): m = Val(brr(1, 7)): r = Val(brr(1, 8))
  16.             rq = DateSerial(y, m, r)
  17.             dh = Mid(brr(1, 1), 6)
  18.             mc = Mid(brr(2, 1), 4)
  19.             s = 0
  20.             For j = 4 To UBound(brr)
  21.                 If brr(j, 2) <> "" Then
  22.                     s = s + 1
  23.                     crr(s, 1) = rq
  24.                     crr(s, 2) = dh
  25.                     crr(s, 3) = mc
  26.                     crr(s, 4) = brr(j, 2)
  27.                     crr(s, 5) = brr(j, 5)
  28.                     crr(s, 6) = brr(j, 6)
  29.                     crr(s, 7) = brr(j, 7)
  30.                     crr(s, 8) = brr(j, 3)
  31.                 End If
  32.             Next
  33.             Cells(n, 1).Resize(s, UBound(crr, 2)) = crr
  34.             n = n + s
  35.         End If
  36.     Next
  37. Next
  38. x = Sheet3.Range("a65536").End(xlUp).Row
  39. If x < 3 Then Exit Sub
  40. Sheet3.Range("a3:h" & x).Copy Cells(n, 1)
  41. ar = Range("a1").CurrentRegion
  42. For i = 3 To UBound(ar)
  43.     d(ar(i, 8)) = d(ar(i, 8)) + ar(i, 7)
  44. Next
  45. For i = 2 To UBound(br)
  46.     d(br(i, 8)) = d(br(i, 8)) + br(i, 7)
  47. Next
  48. For i = 1 To UBound(cr)
  49.     cr(i, 1) = d(cr(i, 1))
  50. Next
  51. Sheets("明细表").Range("e5").Resize(UBound(cr)) = cr
  52. End Sub
复制代码
回复

使用道具 举报

发表于 2014-4-22 20:42 | 显示全部楼层    本楼为最佳答案   
刷新的同时填充明细表数据

试改.zip

315.04 KB, 下载次数: 13

回复

使用道具 举报

 楼主| 发表于 2014-4-22 20:52 | 显示全部楼层
非常感谢
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

小黑屋|手机版|Archiver|Excel精英培训 ( 豫ICP备11015029号 )

GMT+8, 2024-4-27 08:36 , Processed in 0.357667 second(s), 9 queries , Gzip On, Yac On.

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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