ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 同一个工作薄,在指定单元格内汇总各工作表中不同位置的数据之和

[复制链接]

TA的精华主题

TA的得分主题

发表于 2018-7-17 00:22 | 显示全部楼层 |阅读模式
求助各位老师:在同一个工作薄内,通过在“第1天”~“第5天”的工作表中筛选“香蕉”和“广东”两个条件,在指定单元格E内汇总第1天~第4天的“香蕉”采购额,详情请见附件。
1`XS5PZK5G$V$JOVKUS_~L5.png

同一个工作薄,在指定单元格内汇总各工作表中不同位置的数据之和.zip

46.76 KB, 下载次数: 18

TA的精华主题

TA的得分主题

发表于 2018-7-17 06:20 | 显示全部楼层
头像被屏蔽

TA的精华主题

TA的得分主题

发表于 2018-7-17 12:53 来自手机 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
提示: 作者被禁止或删除 内容自动屏蔽

TA的精华主题

TA的得分主题

发表于 2018-7-17 13:29 | 显示全部楼层
  1. Sub test()
  2. Dim Dic, I&, J&, K&, Ar, Sht As Worksheet, Br
  3. Set Dic = CreateObject("scripting.dictionary")
  4. '    Ar = Range("a1").CurrentRegion
  5. '    For I = 3 To UBound(Ar)
  6. '        Dic(Ar(I, 2) & Ar(I, 3)) = 0
  7. '    Next
  8.     For Each Sht In Worksheets
  9.         If Sht.Name <> "汇总" Then
  10.             Br = Sht.Range("a1").CurrentRegion
  11.                 For I = 3 To UBound(Br)
  12.                     Dic(Br(I, 2) & Br(I, 3)) = Br(I, 5) + Dic(Br(I, 2) & Br(I, 3))
  13.                 Next
  14.         Erase Br
  15.         End If
  16.     Next
  17.     Ar = Sheets("汇总").Range("a1").CurrentRegion
  18.     For I = 3 To UBound(Ar)
  19.         Range("e" & I) = Dic(Ar(I, 2) & Ar(I, 3))
  20.     Next
  21. End Sub
复制代码

TA的精华主题

TA的得分主题

发表于 2018-7-17 13:31 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2018-7-17 14:06 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
Option Explicit

Sub a()
Dim arr, i%, d, sh As Worksheet
Set d = CreateObject("Scripting.Dictionary")
For Each sh In Sheets
    If sh.Name <> "汇总" And sh.Name <> "第5天" Then
        arr = sh.[A1].CurrentRegion
            For i = 3 To UBound(arr)
                d(arr(i, 2) & arr(i, 3)) = d(arr(i, 2) & arr(i, 3)) + arr(i, 5)
            Next
    End If
Next
arr = Sheets("汇总").[A1].CurrentRegion
For i = 3 To UBound(arr)
    arr(i, 5) = d(arr(i, 2) & arr(i, 3))
Next
[A1].Resize(UBound(arr), UBound(arr, 2)) = arr
Set d = Nothing
End Sub

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-7-17 16:00 | 显示全部楼层
感谢各位大师的指点,能否在“E列“元格内输入函数公式,直接求得各工作表的数值。
3C$6@@6EC3AQB_A@OH%FVZI.png

TA的精华主题

TA的得分主题

发表于 2018-7-19 13:15 | 显示全部楼层
{=SUM(SUMIFS(INDIRECT(shtname&"!E:E"),INDIRECT(shtname&"!b:b"),汇总!B4,INDIRECT(shtname&"!c:c"),汇总!C4))}

TA的精华主题

TA的得分主题

发表于 2018-7-19 13:17 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
设置shtname={"第1天“,“第2天”,“第3天”,“第4天”,“第5天”}

TA的精华主题

TA的得分主题

 楼主| 发表于 2018-7-24 17:09 | 显示全部楼层
air_lingluan 发表于 2018-7-19 13:17
设置shtname={"第1天“,“第2天”,“第3天”,“第4天”,“第5天”}

楼上的老师,你好。我定义shtname={"第1天“,“第2天”,“第3天”,“第4天”,“第5天”}后,但是数值显示错误#REF!, 能否在我的附件中帮忙编辑编辑。谢谢。
HI9ABP{))1M%9(V)$Z3O)K4.png
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2025-1-10 20:54 , Processed in 0.026800 second(s), 10 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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