ExcelHome技术论坛

 找回密码
 免费注册

QQ登录

只需一步,快速开始

快捷登录

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

[求助] 把明细数据按照模版拆分到同一个工作表的难题

[复制链接]

TA的精华主题

TA的得分主题

发表于 2024-9-4 17:29 | 显示全部楼层 |阅读模式
各位VBA高手:

     我是一个VBA大白,想把明细数据按照模版拆分到同一个工作表,要求如下:
1、我想把明细表中的数据,按照模版的样式一一填充好后,依次向下排好
2、每个模版之间的间隔1行
3、表头序号依次填充
恳请高手相助!


1725441122766.png
1725441598701.png
1725441654968.png

工作簿2.rar

15.25 KB, 下载次数: 15

TA的精华主题

TA的得分主题

发表于 2024-9-4 17:45 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
你这个有点麻烦啊

TA的精华主题

TA的得分主题

发表于 2024-9-4 17:48 | 显示全部楼层
详见附件。

工作簿2.rar

28.22 KB, 下载次数: 23

TA的精华主题

TA的得分主题

 楼主| 发表于 2024-9-4 18:18 | 显示全部楼层
[广告] VBA代码宝 - VBA编程加强工具 · VBA代码随查随用  · 内置多项VBA编程加强工具       ★ 免费下载 ★      ★使用手册
chxw68:
你就是大神!超级感谢

TA的精华主题

TA的得分主题

发表于 2024-9-4 18:52 | 显示全部楼层
完善了两点:一是每个表格中间加了分页符;二是根据模板表设置了结果表中的行高。

工作簿2.rar

29.96 KB, 下载次数: 42

TA的精华主题

TA的得分主题

发表于 2024-9-4 20:42 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
Option Explicit
Sub TEST2()
    Dim ar, br(), cr, i&, j&, k&, n&, r&, Rng As Range
   
    Application.ScreenUpdating = False
   
    With Worksheets("明细").[A1].CurrentRegion
        ar = .Value
        For i = 2 To UBound(ar)
            If Len(ar(i, 1)) Then
                r = r + 1
                ReDim Preserve br(1 To 2, 1 To r)
                br(1, r) = i
            End If
        Next i
        For j = 1 To UBound(br, 2)
            If j = UBound(br, 2) Then
                br(2, j) = .Cells(br(1, j), 1).Resize(UBound(ar) - br(1, j) + 1).Resize(, UBound(ar, 2))
            Else
                br(2, j) = .Cells(br(1, j), 1).Resize(br(1, j + 1) - br(1, j)).Resize(, UBound(ar, 2))
            End If
        Next j
        
        ar = Array(1, 2, 3, 7, 9, 10, 11)
        For k = 1 To UBound(br, 2)
            ReDim cr(1 To 5, 1 To 11)
            For i = 1 To UBound(br(2, k))
                For j = 0 To UBound(ar)
                    cr(i, ar(j)) = br(2, k)(i, j + 16)
                Next j
            Next i
            br(1, k) = cr
        Next k
    End With
   
    Set Rng = Worksheets("模板").[A1:L12]
    ar = [{"B2","D2","F2","H2","J2","L2","B3","E3","H3","J3","L3","C4","E4","I4","K4"}]
    With Worksheets("样例")
        .Cells.Delete
        For i = 1 To UBound(br, 2)
            n = (i - 1) * 13 + 1
            With .Cells(n, 1)
                rngCopyToSame Rng, .Range("A1")
                .Range("A1") = "失业人员就业帮扶记录(" & i & ")号"
                For j = 1 To UBound(ar)
                    .Range(ar(j)).Value = br(2, i)(1, j)
                Next j
                .Range("A8").Resize(UBound(br(1, i)), UBound(br(1, i), 2)) = br(1, i)
            End With
        Next i
        .Activate
    End With
   
    Application.ScreenUpdating = True
    Beep
End Sub
Function rngCopyToSame(ByVal rngSel As Range, ByVal rngTarget As Range)
    Dim i&
    rngSel.Copy
    rngTarget.PasteSpecial xlPasteColumnWidths
    rngSel.Copy rngTarget
    With rngTarget.Resize(rngSel.Rows.Count, rngSel.Columns.Count)
        For i = 1 To .Rows.Count
            .Rows(i).RowHeight = rngSel.Rows(i).RowHeight
        Next i
    End With
End Function

TA的精华主题

TA的得分主题

发表于 2024-9-4 20:43 | 显示全部楼层
请参考附件。。。

工作簿2.rar

30.91 KB, 下载次数: 24

TA的精华主题

TA的得分主题

发表于 2024-9-4 21:15 | 显示全部楼层
  1. Sub qs()
  2. Dim arr, i, dic, r
  3. Set dic = CreateObject("scripting.dictionary")
  4. arr = Sheet3.Range("a2:v" & Sheet3.Cells(Rows.Count, "v").End(xlUp).Row)
  5. a = [{"B2","D2","F2","H2","J2","L2","B3","E3","H3","J3","L3","G4","E4","I4","K4"}]
  6. b = [{1,2,3,7,9,10,12}]
  7. For i = 1 To UBound(arr)
  8.     If arr(i, 1) = "" Then
  9.         For j = 1 To 15
  10.             arr(i, j) = arr(i - 1, j)
  11.         Next
  12.      End If
  13.    If Not dic.exists(arr(i, 1)) Then
  14.     dic(arr(i, 1)) = i
  15.    Else
  16.     dic(arr(i, 1)) = dic(arr(i, 1)) & "|" & i
  17.    End If
  18. Next
  19. With Sheet2
  20.     For Each k In dic.keys
  21.          xx = Split(dic(k), "|")
  22.         m = m + 1
  23.         .Range("a1").Value = "失业人员就业帮扶记录(" & m & ")号"
  24.         For j = 1 To 15
  25.             .Range(a(j)) = ""
  26.             .Range(a(j)) = arr(Val(xx(0)), j)
  27.         Next
  28.         .Range("a8:l100").ClearContents
  29.         rw = 7
  30.         For y = 0 To UBound(xx)
  31.         rw = rw + 1
  32.             For x = 1 To UBound(b)
  33.                 .Cells(rw, b(x)).Value = arr(Val(xx(y)), x + 15)
  34.             Next x
  35.         Next y
  36.         If Sheets("结果表").Range("a1") = "" Then
  37.         .Range("a1:l" & rw).Copy Sheets("结果表").Range("a1")
  38.         Else
  39.             r2 = Sheets("结果表").Cells(Rows.Count, 1).End(3).Row + 2
  40.             .Range("a1:l" & rw).Copy Sheets("结果表").Range("a" & r2)
  41.         End If
  42.     Next
  43. End With
  44. Sheet5.Activate
  45. MsgBox "拆分结果在结果表"
  46. End Sub
复制代码

TA的精华主题

TA的得分主题

发表于 2024-9-4 21:16 | 显示全部楼层

TA的精华主题

TA的得分主题

发表于 2024-9-4 21:17 | 显示全部楼层
[广告] Excel易用宝 - 提升Excel的操作效率 · Excel / WPS表格插件       ★免费下载 ★       ★ 使用帮助
试试............

把明细数据按照模版拆分到同一个工作表.rar

32.95 KB, 下载次数: 21

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

本版积分规则

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

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

Powered by Discuz! X3.4

© 1999-2023 Wooffice Inc.

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

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

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