ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] vba批量汇总求和(多条件匹配多工作簿多列多条件分列求和)

[复制链接]

TA的精华主题

TA的得分主题

发表于 2023-4-6 21:41 | 显示全部楼层 |阅读模式
本帖最后由 he_zai 于 2023-4-9 09:45 编辑

模仿vlookup实现多条件匹配
效果图: image.png
数据源 image.png
年金数据源 image.png
要求:根据身份号+正常应缴(正常补收)查找所有工作簿并复制到相应行、列
现缺点:失业数据源,有一些名字是两行数据,一行是零,要排序后才能匹配第一个,希望大神再改进为,失业、工伤的值条件相同的话   相加
代码
重复的情况有两种,
1-养老,年金,医疗,重复身份证号码为一行是正常应缴,一行是正常补收
2-失业工作簿里面,情况除上面的外,还有工伤列,有些和失业列一行,有些不在同一行,所以这个工作簿想同的身份证号码可以有四行(正常应缴2行),(正常补收2行),因此这工作簿的,同身份证号码,同正常应缴或者正常补收,应为累加(求和)

  1. Sub 快速匹配()    '子程序 byWanao()
  2. Dim arr, brr(), sht As Worksheet, WB As Workbook, shtt As Worksheet    '定义变量 arr,brr(),sht 为 工作表,WB 为 工作簿,shtt 为 工作表
  3. Dim 年金 As String, 养老 As String, 医疗 As String, 失业 As String    '定义变量 年金 为 字符串,养老 为 字符串,医疗 为 字符串,失业 为 字符串
  4. 年金 = "202304 征集明细 年金"    ' 年金="202304征集明细年金"
  5. 养老 = "202304 征集明细 养老"    '养老="202304征集明细养老"
  6. 失业 = "202304 征集明细 失业"    '失业="202304征集明细失业"
  7. 医疗 = "单位参保职工缴费明细"    '医疗="单位参保职工缴费明细"
  8. ThisWorkbook.Sheets("Sheet1").[e2:h426].ClearContents    '<当前工作簿>的<工作表>"Sheet1" )的[e2 :h426]的清除内容
  9. ThisWorkbook.Sheets("Sheet1").[k2:n426].ClearContents    '<当前工作簿>的<工作表>"Sheet1" )的[k2 :n426]的清除内容
  10. Path = ThisWorkbook.Path & "\扣款明细源"    '路径= 当前工作簿的路径 & "\扣款明细源"
  11. Filename = Dir(Path & "*.xls", vbDirectory)    ' 文件名=<查找文件或目录>(路径 & "*.xls",vbDirectory)
  12. Do    '执行循环操作
  13.     If Len(Filename) = 0 Then Exit Do    '如果 <字符串长度值>( 文件名)=0 则执行 退出执行循环操作
  14.     Set sht = ThisWorkbook.Sheets("Sheet1")    '设定sht=<当前工作簿>的<工作表>"Sheet1")
  15.     Set WB = Workbooks.Open(Path & Filename)    '设定WB= 工作簿集合的Open(路径 &  文件名)
  16.     Application.ScreenUpdating = False    '关闭屏幕刷新(可以提高运行速度)
  17.     For Each shtt In WB.Sheets    '设定变量范围为每一个shtt位于 WB的表单集合
  18.         If shtt.Name = 年金 Then    '如果  shtt的名称=年金 则执行
  19.             With Sheets(年金)    '工作于<工作表>(年金)
  20.                 For i = 2 To sht.Cells(Rows.Count, 1).End(xlUp).Row    '设定变量范围为i=2到 sht的<单元格>坐标(行数值,1 )的<末端>(方向向上 )的行标
  21.                     For j = 2 To .Cells(Rows.Count, 1).End(xlUp).Row    '设定变量范围为j=2到<With对象>的<单元格>坐标(行数值,1 )的<末端>(方向向上 )的行标
  22.                         If sht.Cells(i, 3) & "正常应缴" = .Cells(j, 6) & .Cells(j, 7) Then    '如果  sht的<单元格>坐标(i,3) & "正常应缴"=<With对象>的<单元格>坐标(j,6) & <With对象>的<单元格>坐标(j,7) 则执行
  23.                             sht.Cells(i, 6) = .Cells(j, 16)    ' sht的<单元格>坐标(i,6)=<With对象>的<单元格>坐标(j,16)
  24.                         ElseIf sht.Cells(i, 3) & "正常补收" = .Cells(j, 6) & .Cells(j, 7) Then    '另外如果 sht的<单元格>坐标(i,3) & "正常补收"=<With对象>的<单元格>坐标(j,6) & <With对象>的<单元格>坐标(j,7) 则执行
  25.                             sht.Cells(i, 12) = .Cells(j, 16)    ' sht的<单元格>坐标(i,12)=<With对象>的<单元格>坐标(j,16)
  26.                             Exit For    '退出for循环
  27.                         Else    '另外
  28.                         End If    'If判断过程结束
  29.                     Next    '下一个
  30.                 Next    '下一个
  31.             End With    'With语句结束
  32.         End If    'If判断过程结束
  33.         If shtt.Name = 养老 Then    '如果  shtt的名称=养老 则执行
  34.             With Sheets(养老)    '工作于<工作表>(养老)
  35.                 For i = 2 To sht.Range("A10000").End(xlUp).Row    '设定变量范围为i=2到 sht的<单元格>区域("A10000" )的<末端>(方向向上 )的行标
  36.                     For j = 2 To .Range("A10000").End(xlUp).Row    '设定变量范围为j=2到<With对象>的<单元格>区域("A10000" )的<末端>(方向向上 )的行标
  37.                         If sht.Cells(i, 3) & "正常应缴" = .Cells(j, 6) & .Cells(j, 7) Then    '如果  sht的<单元格>坐标(i,3) & "正常应缴"=<With对象>的<单元格>坐标(j,6) & <With对象>的<单元格>坐标(j,7) 则执行
  38.                             sht.Cells(i, 5) = .Cells(j, 12)    ' sht的<单元格>坐标(i,5)=<With对象>的<单元格>坐标(j,12)
  39.                         ElseIf sht.Cells(i, 3) & "正常补收" = .Cells(j, 6) & .Cells(j, 7) Then    '另外如果 sht的<单元格>坐标(i,3) & "正常补收"=<With对象>的<单元格>坐标(j,6) & <With对象>的<单元格>坐标(j,7) 则执行
  40.                             sht.Cells(i, 11) = .Cells(j, 12)    ' sht的<单元格>坐标(i,11)=<With对象>的<单元格>坐标(j,12)
  41.                             Exit For    '退出for循环
  42.                         Else    '另外
  43.                         End If    'If判断过程结束
  44.                     Next    '下一个
  45.                 Next    '下一个
  46.             End With    'With语句结束
  47.         End If    'If判断过程结束
  48.         If shtt.Name = 失业 Then    '如果  shtt的名称=失业 则执行
  49.             With Sheets(失业)    '工作于<工作表>(失业)
  50.                 Range("a1:ad1000").Sort Range("x2"), xlAscending    '<单元格>区域("a1:ad1000" )的排序 <单元格>区域("x2"),升序
  51.                 For i = 2 To sht.Cells(Rows.Count, 1).End(xlUp).Row    '设定变量范围为i=2到 sht的<单元格>坐标(行数值,1 )的<末端>(方向向上 )的行标
  52.                     For j = 2 To .Cells(Rows.Count, 1).End(xlUp).Row    '设定变量范围为j=2到<With对象>的<单元格>坐标(行数值,1 )的<末端>(方向向上 )的行标
  53.                         If sht.Cells(i, 3) & "正常应缴" = .Cells(j, 6) & .Cells(j, 7) Then    '如果  sht的<单元格>坐标(i,3) & "正常应缴"=<With对象>的<单元格>坐标(j,6) & <With对象>的<单元格>坐标(j,7) 则执行
  54.                             sht.Cells(i, 7) = .Cells(j, 24)    ' sht的<单元格>坐标(i,7)=<With对象>的<单元格>坐标(j,24)
  55.                         ElseIf sht.Cells(i, 3) & "正常补收" = .Cells(j, 6) & .Cells(j, 7) Then    '另外如果 sht的<单元格>坐标(i,3) & "正常补收"=<With对象>的<单元格>坐标(j,6) & <With对象>的<单元格>坐标(j,7) 则执行
  56.                             sht.Cells(i, 13) = .Cells(j, 24)    ' sht的<单元格>坐标(i,13)=<With对象>的<单元格>坐标(j,24)
  57.                             Exit For    '退出for循环
  58.                         Else    '另外
  59.                         End If    'If判断过程结束
  60.                     Next    '下一个
  61.                 Next    '下一个
  62.             End With    'With语句结束
  63.         End If    'If判断过程结束
  64.         If shtt.Name = 医疗 Then    '如果  shtt的名称=医疗 则执行
  65.             With Sheets(医疗)    '工作于<工作表>(医疗)
  66.                 For i = 2 To sht.Cells(Rows.Count, 1).End(xlUp).Row    '设定变量范围为i=2到 sht的<单元格>坐标(行数值,1 )的<末端>(方向向上 )的行标
  67.                     For j = 2 To .Cells(Rows.Count, 1).End(xlUp).Row    '设定变量范围为j=2到<With对象>的<单元格>坐标(行数值,1 )的<末端>(方向向上 )的行标
  68.                         If sht.Cells(i, 3) & "正常应缴" = .Cells(j, 4) & .Cells(j, 10) Then    '如果  sht的<单元格>坐标(i,3) & "正常应缴"=<With对象>的<单元格>坐标(j,4) & <With对象>的<单元格>坐标(j,10) 则执行
  69.                             sht.Cells(i, 8) = .Cells(j, 13)    ' sht的<单元格>坐标(i,8)=<With对象>的<单元格>坐标(j,13)
  70.                         ElseIf sht.Cells(i, 3) & "正常补收" = .Cells(j, 4) & .Cells(j, 10) Then    '另外如果 sht的<单元格>坐标(i,3) & "正常补收"=<With对象>的<单元格>坐标(j,4) & <With对象>的<单元格>坐标(j,10) 则执行
  71.                             sht.Cells(i, 14) = .Cells(j, 13)    ' sht的<单元格>坐标(i,14)=<With对象>的<单元格>坐标(j,13)
  72.                             Exit For    '退出for循环
  73.                         Else    '另外
  74.                         End If    'If判断过程结束
  75.                     Next    '下一个
  76.                 Next    '下一个
  77.             End With    'With语句结束
  78.         End If    'If判断过程结束
  79.     Next    '下一个
  80.     WB.Close False    ' WB的关闭 False
  81.     Filename = Dir()    ' 文件名=<查找文件或目录>()
  82. Loop    '循环执行
  83. End Sub    '子程序结束


复制代码




vba多条件汇总多工作簿.zip

1.69 MB, 下载次数: 28

TA的精华主题

TA的得分主题

 楼主| 发表于 2023-4-7 18:54 来自手机 | 显示全部楼层
样表格里面的姓名,身份证号码全部随机生成

TA的精华主题

TA的得分主题

发表于 2023-4-7 20:34 来自手机 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
失业数据源,有一些名字是两行数据,一行是零,要排序后才能匹配第一个,


数据来源能否行数少些?没发现你提到的情况

TA的精华主题

TA的得分主题

 楼主| 发表于 2023-4-8 09:24 来自手机 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
zpy2 发表于 2023-4-7 20:34
失业数据源,有一些名字是两行数据,一行是零,要排序后才能匹配第一个,



那应该是随机生成名字或者身份证号时,忘记设计重复了
重复的情况有两种,
1-养老,年金,医疗,重复身份证号码为一行是正常应缴,一行是正常补收
2-失业工作簿里面,情况除上面的外,还有工伤列,有些和失业列一行,有些不在同一行,所以这个工作簿想同的身份证号码可以有四行(正常应缴2行),(正常补收2行),因此这工作簿的,同身份证号码,同正常应缴或者正常补收,应为累加(求和)

TA的精华主题

TA的得分主题

 楼主| 发表于 2023-4-9 18:32 来自手机 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2024-9-29 23:01 来自手机 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2024-11-23 21:08 | 显示全部楼层
用Excel做企业管理系统,Excel服务器学习和下载★
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2025-1-5 10:18 , Processed in 0.024967 second(s), 11 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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