ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

如何使用代码实现 根据汇总表中B列部门名称,提取其他表中内容

[复制链接]

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-2-22 21:15 | 显示全部楼层
ykcbf1100 发表于 2024-2-22 11:47
代码如下,按自选部门查询。

查询部门可以修改成J列一列吗?就像图片中一样,或者就是J2到J41单元格每个单元格可以输入需要查询部门,按照我输入的部门从上到下按顺序匹配部门提取文件,如果J2列有的部门,在上级考核和自查考核工作表中没有,就跳过继续匹配和提取后面的部门数据。还有一个问题就是 我新增一个别的工作表后,代码就出错了,能不受新增工作表限制吗?
捕获16.JPG

TA的精华主题

TA的得分主题

发表于 2024-2-23 07:43 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
xpmiemiezhou 发表于 2024-2-22 21:15
查询部门可以修改成J列一列吗?就像图片中一样,或者就是J2到J41单元格每个单元格可以输入需要查询部门, ...

改好了。。。

考核表(自选部门查询)2.7z

140.08 KB, 下载次数: 11

TA的精华主题

TA的得分主题

发表于 2024-2-23 07:44 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
2024.2.23代码更新。
  1. Sub ykcbf()   '//2024.2.23
  2.     Dim arr, d, zr
  3.     Application.ScreenUpdating = False
  4.     Application.DisplayAlerts = False
  5.     Set d = CreateObject("Scripting.Dictionary")
  6.     Set d1 = CreateObject("Scripting.Dictionary")
  7.     Set ws = ThisWorkbook
  8.     Set sh = ws.Sheets("考核汇总")
  9.     With sh
  10.         r = .Cells(Rows.Count, "j").End(3).Row
  11.         zrr = .Range("j2:j" & r)
  12.     End With
  13.     For i = 1 To UBound(zrr)
  14.         k = zrr(i, 1)
  15.         d1(k) = ""
  16.     Next
  17.     On Error Resume Next
  18.     For Each sht In ws.Sheets
  19.         If sht.Name <> sh.Name Then
  20.             If IsArray(sht.UsedRange) Then
  21.                 With sht
  22.                     fn = .Name
  23.                     arr = .UsedRange
  24.                     c = .Rows(2).Find("小计", , , , , 1).Column
  25.                 End With
  26.                 p4 = IIf(InStr(fn, "自查"), "自查", "")
  27.                 For i = 3 To UBound(arr)
  28.                     If d1.exists(arr(i, 2)) Then
  29.                         s = arr(i, 2) & "|" & arr(i, 3) & "|" & arr(i, 4) & "|" & arr(i, 5) & "|" & p4
  30.                         d(s) = arr(i, c)
  31.                     End If
  32.                 Next
  33.             End If
  34.         End If
  35.     Next
  36.     ReDim brr(1 To d.Count, 1 To 8)
  37.     For Each k In d.keys
  38.         m = m + 1
  39.         b = Split(k, "|")
  40.         brr(m, 1) = m
  41.         brr(m, 2) = b(0)
  42.         brr(m, 3) = b(1)
  43.         brr(m, 4) = b(2)
  44.         brr(m, 5) = b(3)
  45.         brr(m, 6) = d(k)
  46.         brr(m, 8) = b(4)
  47.     Next
  48.     With sh
  49.         .[a3:h10000].UnMerge
  50.         .[a3:h10000].Clear
  51.         With .[a3].Resize(m, 8)
  52.             .Value = brr
  53.             .Borders.LineStyle = 1
  54.             .HorizontalAlignment = xlCenter
  55.             .VerticalAlignment = xlCenter
  56.         End With
  57.         .[a3].Resize(m, 8).Sort .[b3], 1
  58.         zr = Array(1, 2, 7)
  59.         Call hb(3, 2, zr)
  60.         Call hbsum(3, 4, 6, 7)
  61.     End With
  62.     Set d = Nothing
  63.     Application.ScreenUpdating = True
  64.     MsgBox "OK!"
  65. End Sub
复制代码


TA的精华主题

TA的得分主题

 楼主| 发表于 2024-2-23 09:51 | 显示全部楼层
ykcbf1100 发表于 2024-2-23 07:44
2024.2.23代码更新。

老大,还是不对哦,要按查询部门的部门顺序提取,查询部门第一个是部门2就提取部门2的排在第一,B列部门名称顺序要跟J列部门顺序一样。辛苦大哥,向你致敬!
捕获18.JPG

TA的精华主题

TA的得分主题

发表于 2024-2-23 09:58 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
xpmiemiezhou 发表于 2024-2-23 09:51
老大,还是不对哦,要按查询部门的部门顺序提取,查询部门第一个是部门2就提取部门2的排在第一,B列部门 ...

不要要求那么高了。
不再跟进。

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-2-23 13:42 | 显示全部楼层
ykcbf1100 发表于 2024-2-23 09:58
不要要求那么高了。
不再跟进。

谢谢啦!!!

TA的精华主题

TA的得分主题

发表于 2024-2-23 14:48 | 显示全部楼层
本帖最后由 saghj 于 2024-2-23 14:52 编辑

牛逼!

考核表.rar

26.39 KB, 下载次数: 8

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-2-23 17:45 | 显示全部楼层
shiruiqiang 发表于 2024-2-20 14:29
按照你的要求,可以少写几句

根据你写的代码,我自己试着修改了一下我需要更改的地方,但是新增几个工作表我要另做他用时,这个代码就会出现13错误,能不能帮忙修改一下,我新增的表格可以做其他事情,不影响原来汇总表汇总原有两个分表数据

考核表1.rar

37.51 KB, 下载次数: 1

TA的精华主题

TA的得分主题

发表于 2024-2-23 18:29 | 显示全部楼层
xpmiemiezhou 发表于 2024-2-23 17:45
根据你写的代码,我自己试着修改了一下我需要更改的地方,但是新增几个工作表我要另做他用时,这个代码就 ...

image.jpg

考核表1.rar

47.87 KB, 下载次数: 8

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-2-23 19:18 | 显示全部楼层
您需要登录后才可以回帖 登录 | 免费注册

本版积分规则

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

GMT+8, 2024-9-30 04:28 , Processed in 0.039646 second(s), 6 queries , Gzip On, MemCache On.

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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