ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

EH搜索     
EH云课堂-专业的职场技能充电站 妙哉!函数段子手趣味讲函数 Excel服务器-会Excel,做管理系统 Excel Home精品图文教程库
Excel不给力? 何不试试FoxTable! Excel 2016函数公式学习大典 EH云课堂直播课程免费学 打造核心竞争力的职场宝典
300集Office 2010微视频教程 Tableau-数据可视化工具 精品推荐-800套精选PPT模板,点击获取 ExcelHome出品 - VBA代码宝免费下载
你的Excel 2010实战技巧学习锦囊 欲罢不能, 过目难忘的 Office 新界面 Excel VBA经典代码实践指南
查看: 1792|回复: 8

[求助] 从总表数据源中提取自己想要的数据

[复制链接]

TA的精华主题

TA的得分主题

发表于 2017-6-2 19:33 | 显示全部楼层 |阅读模式


   如题,已有总表数据源,如何提取已制定格式的符合数据,

    谢谢!       附件:    2016.zip (21.25 KB, 下载次数: 34)

TA的精华主题

TA的得分主题

 楼主| 发表于 2017-6-2 21:03 来自手机 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2017-6-2 22:45 | 显示全部楼层
  1. Sub ehkjxg()
  2.     Dim d As Object, arr, brr, r, i&, j&, k&, t
  3.     'On Error Resume Next
  4.     Set d = CreateObject("scripting.dictionary")
  5.     arr = Sheets(1).[a1].CurrentRegion
  6.     For i = 1 To UBound(arr)
  7.         t = arr(i, 2) & arr(i, 3) & arr(i, 1) '部门类别时间
  8.         d(t) = d(t) + arr(i, 4)
  9.     Next
  10.     Sheets("按類別分析").Select
  11.     [d3:p44].ClearContents
  12.     brr = [b2:p44]
  13.     For i = 2 To UBound(brr)
  14.         If brr(i, 1) = "" Then brr(i, 1) = brr(i - 1, 1)
  15.         For j = 3 To UBound(brr, 2) - 1
  16.             t = brr(i, 2) & brr(i, 1) & brr(1, j)
  17.             If d.exists(t) Then
  18.                 brr(i, j) = d(t)
  19.             End If
  20.         Next
  21.     Next
  22.     [b2:p44] = brr
  23.     [d2:p44].SpecialCells(xlCellTypeBlanks).Select
  24.     Application.SendKeys "%="
  25.     Set d = Nothing
  26. End Sub
复制代码

评分

参与人数 1鲜花 +2 收起 理由
yf_home + 2 感谢帮助

查看全部评分

TA的精华主题

TA的得分主题

 楼主| 发表于 2017-6-3 08:32 | 显示全部楼层




感謝星光老師, 經測試, 這句不能用.


Application.SendKeys "%="


另外, 麻煩幫忙把代碼註釋下, 因為還有一個 按部門分析 沒有完成,


我自己試著修改下, 謝謝.

TA的精华主题

TA的得分主题

发表于 2017-6-3 10:24 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2017-6-3 10:25 | 显示全部楼层
建议楼主用数据透视表

2016.zip

33.31 KB, 下载次数: 4

TA的精华主题

TA的得分主题

 楼主| 发表于 2017-6-3 10:27 | 显示全部楼层
苏阳湖wzy 发表于 2017-6-3 10:24
建议楼主用数据透视表

数据透视表,达不到这样的效果,只能用VBA实现。

TA的精华主题

TA的得分主题

发表于 2017-6-3 10:56 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2017-6-3 14:07 | 显示全部楼层
  1. Sub 汇总()
  2.     Dim vData As Variant, nRow As Double, nCol As Integer, oDic As Object, vKey As Variant
  3.     Dim sMonth As String, sDpt As String, sType As String, nVal As Double
  4.     Dim vSH As Variant, nSH As Integer, vFill As Variant
  5.    
  6.     Set oDic = CreateObject("Scripting.Dictionary")
  7.     vSH = [{"按類別分析","按部門分析"}]
  8.     vData = Sheets("總表").[B2].CurrentRegion.Value
  9.     For nRow = 2 To UBound(vData)
  10.         sMonth = Trim(vData(nRow, 1))
  11.         sDpt = Trim(vData(nRow, 2))
  12.         sType = Trim(vData(nRow, 3))
  13.         nVal = Val(vData(nRow, 4))
  14.         If sMonth <> "" And sDpt <> "" And sType <> "" Then
  15.             oDic(sMonth & "|" & sDpt & "|" & sType) = nVal '每月、每部门、每成本类别的金额
  16.             oDic(sMonth & "|" & sDpt & "|" & "成本小計") = oDic(sMonth & "|" & sDpt & "|" & "成本小計") + nVal '每月、每部门的成本小计
  17.             oDic(sMonth & "|" & sType & "|" & sDpt) = nVal '每月、每成本类别、每部门的金额
  18.             oDic(sMonth & "|" & sType & "|" & "成本小計") = oDic(sMonth & "|" & sType & "|" & "成本小計") + nVal '每月、每成本类别的成本小计
  19.             oDic("加總|" & sDpt & "|" & sType) = oDic("加總|" & sDpt & "|" & sType) + nVal '每部门、每成本类别的总计
  20.             oDic("加總|" & sType & "|" & sDpt) = oDic("加總|" & sType & "|" & sDpt) + nVal '每部门、每成本类别的总计
  21.             oDic("加總|" & sDpt & "|成本小計") = oDic("加總|" & sDpt & "|成本小計") + nVal '每部门的总计
  22.             oDic("加總|" & sType & "|成本小計") = oDic("加總|" & sType & "|成本小計") + nVal '每成本类别的总计
  23.         End If
  24.     Next
  25.     For nSH = 0 To 1
  26.         With Sheets(vSH(nSH + 1))
  27.             vData = .[B2].CurrentRegion.Value
  28.             vFill = Empty
  29.             Debug.Print .[A2].CurrentRegion.Address
  30.             ReDim vFill(2 To UBound(vData), 3 To UBound(vData, 2))
  31.             vKey = Empty
  32.             ReDim vKey(1 To 2)
  33.             For nRow = 2 To UBound(vData)
  34.                 vKey(1) = Trim(vData(nRow, 1))
  35.                 vKey(2) = Trim(vData(nRow, 2))
  36.                 If vKey(1 - (nSH = 1) * 1) = "" Then
  37.                     vKey(1 - (nSH = 1) * 1) = sDpt
  38.                 Else
  39.                     sDpt = vKey(1 - (nSH = 1) * 1)
  40.                 End If
  41.                 If vKey(2 + (nSH = 1) * 1) = "" Then
  42.                     vKey(2 + (nSH = 1) * 1) = sType
  43.                 Else
  44.                     sType = vKey(2 + (nSH = 1) * 1)
  45.                 End If
  46.                 For nCol = 3 To UBound(vData, 2)
  47.                     sMonth = Trim(vData(1, nCol))
  48.                     vFill(nRow, nCol) = oDic(sMonth & "|" & vKey(1) & "|" & vKey(2))
  49.                 Next
  50.             Next
  51.             .[D3].Resize(UBound(vFill) - 1, UBound(vFill, 2) - 2) = vFill
  52.         End With
  53.     Next
  54. End Sub
复制代码

TA的精华主题

TA的得分主题

发表于 2017-6-3 14:07 | 显示全部楼层
附上附件以供参考

2016(By.Micro).rar

24.46 KB, 下载次数: 49

评分

参与人数 2鲜花 +4 收起 理由
凯哥003 + 2 太强大了
yf_home + 2 太强大了

查看全部评分

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

本版积分规则

关闭

最新热点上一条 /1 下一条

关注官方微信,高效办公专列,每天发车

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

GMT+8, 2020-2-21 11:26 , Processed in 0.448397 second(s), 24 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2020 Wooffice Inc.

   

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

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

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