ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

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

[复制链接]

TA的精华主题

TA的得分主题

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


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

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



...

TA的精华主题

TA的得分主题

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

TA的精华主题

TA的得分主题

发表于 2017-6-2 22:45 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
  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

查看全部评分

TA的精华主题

TA的得分主题

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




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


Application.SendKeys "%="


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


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

TA的精华主题

TA的得分主题

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

TA的精华主题

TA的得分主题

发表于 2017-6-3 10:25 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
建议楼主用数据透视表

2016.zip

33.31 KB, 下载次数: 15

TA的精华主题

TA的得分主题

 楼主| 发表于 2017-6-3 10:27 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
苏阳湖wzy 发表于 2017-6-3 10:24
建议楼主用数据透视表

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

TA的精华主题

TA的得分主题

发表于 2017-6-3 10:56 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
应该可以的呀,表格只要稍微修改一下即可

TA的精华主题

TA的得分主题

发表于 2017-6-3 14:07 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
  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 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
附上附件以供参考

2016(By.Micro).rar

24.46 KB, 下载次数: 70

评分

2

查看全部评分

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

本版积分规则

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

GMT+8, 2024-3-28 22:07 , Processed in 0.047120 second(s), 10 queries , Gzip On, Redis On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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