打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
在Excel中按指定的重复次数填充数据到一列

      在工作中有时需要将Excel某列中的数据按指定的次数依次重复填充到另一列。例如在下图的示例中,要将A列的编号 按B列对应次数重复填充到D列,即首先将第一个编号“WOY756”在D列中填充2次,接着将第二个编号“QLG752”填充1次,将第三个编号 “RWR880”填充5次,……。

    


 

      可用数组公式或VBA来实现这样的填充,在D2单元格输入下面的数组公式后按Ctrl+Shift+Enter结束(下同),然后拖动填充柄向下填充公式,直到最后一个编号按指定的次数全部出现为止。

      公式1:

    =OFFSET(A$1,MIN(IF(COUNTIF($D$1:D1,A$2:A$21)<B$2:B$21,ROW(A$1:A$20))),)

      说明:COUNTIF函数统计公式所在单元格以上区域中所产生的各个“编号”数量,将其与B列对应次数进行对比,如果未达到B列对应次数,则返回“编号” 相对A1单元格的偏移量,否则返回“FALSE”,这将得到一个包含“FALSE”和偏移量的数组。MIN函数取得最小值,即“编号”的偏移量,最后用 OFFSET函数返回“编号”。

      公式2:

    =INDEX(A$1:A$21,SMALL(IF($B$2:$B$21>=COLUMN($A:$J),ROW($B$2:$B$21)),ROW(A1)))

      说明:“IF($B$2:$B$21>=COLUMN($A:$J),ROW($B$2:$B$21))”产生一个20行10列由FALSE和数字组成的数组(本例A列共 有20个数据,最大重复次数为10),其中的数字为各“编号”对应的行号,且各数字的数量与B列的重复次数相同。如16行“BXQ763”对应的“重复次 数”为3,数组中即包含3个“16”。“COLUMN($A:$J)”需根据B列的最大值进行修改,例如“重复次数”中最大值为26,则改为 “COLUMN($A:$Z)”。

      公式3:

    =INDEX(A$2:A$21,MATCH(ROW(A1)-1,SUBTOTAL(9,OFFSET(B$1,,,ROW($1:$21))),1))

      说明:MATCH函数的第二个参数“SUBTOTAL(9,OFFSET(B$1,,,ROW($1:$21)))”,在本例中产生一个对B列数字进行累 加的内存数组“{0;2;3;8;10;13;22;29;31;37;44;46;56;59;69;72;75;85;94;97;99}”,第三个 参数为“1”,MATCH函数会查找小于或等于第一个参数的最大值,并返回其在数组中的相对位置,即A2:A21区域中的相对行号。例如对于D17单元 格,MATCH函数的第一个参数“ROW(A16)-1”返回15,数组中小于等于15的最大值为13,13处于数组中的第6个位置,MATCH函数返回 6,公式返回A2:A21区域中的第6行数据,即编号“JGN347”。

      如果数据量较大,用下面的VBA代码较为快捷。按Alt+F11,打开VBA编辑器,在代码窗口中粘贴下列代码并运行即可。

Sub 按指定次数重复数据()
Dim Rng, Arr()
Dim i As Integer, j As Integer, k   As Integer
Dim LastRow As Integer, Total As Integer
LastRow = [A65536].End(xlUp).Row
Total = Application.WorksheetFunction.Sum(Range('B2:B' & LastRow))
Rng = Range('A1:B' & LastRow)
ReDim Arr(1 To Total, 1 To 1)
For i = 2 To UBound(Rng, 1)
    For j = 1 To Rng(i, 2)
        k = k + 1
        Arr(k, 1) = Rng(i, 1)
    Next
Next
Range('D2').Resize(k, 1).Value = Arr
End Sub

怎么样?大家学到了吗?

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
如何按指定次数重复数据
Excel VLOOKUP进阶
万千重复里找到属于你要的唯一真爱,这3招一招狠似一招!
按指定次数重复内容的套路合集
计算“-”连续出现的最大次数?不用数,用这个 Excel 函数就能算
完全手册Excel VBA典型实例大全:通过368个例子掌握
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服