python 按条件选择行和列数据_Microsoft Excel怎么按条件快速将总表数据拆分成多个工作表?...

5bae91e664be1c62b9d706c3e087fc75.png

知识改变命运,科技成就未来。在使用Microsoft Excel统计数据时,一般情况下会将各类数据汇总到一个工作表中。当需要分类数据时,使用【筛选】功能的话重复性操作太多,还需要将筛选后的数据进行复制粘贴,有什么办法能够按条件快速的将总表数据拆分成多个工作表?这个时候就需要用到强大的Visual Basic for Applications(VBA)了。

Microsoft Excel按条件快速将总表数据拆分成多个工作表详细操作流程:

第一步:左键双击打开素材文件【将总表数据拆分成多个工作表.xlsx】Microsoft Excel工作表。要编辑VBA代码,首先我们需要打开【Visual Basic编辑器】,右键单击【总表】工作表,左键单击右键菜单中的【查看代码(V)】即可打开【Visual Basic编辑器】。

0ef7eae6c80c826021618437a2ff825c.png

第二步:编辑VBA代码。左键单击【工程资源管理器】中的【Sheet1 总表】后,在右侧代码窗口中键入以下代码,您也可以选择复制粘贴。代码输入完成后,不需要保存,直接关闭【Visual Basic编辑器】即可。

82cf3a91424fb1741a955c6f6ee293b0.png

Sub NewSheets()

Dim d As Object, sht As Worksheet, arr, brr, r, kr, i&, j&, k&, x&

Dim Rng As Range, Rg As Range, tRow&, tCol&, aCol&, pd&

Application.ScreenUpdating = False

Application.DisplayAlerts = False

Set d = CreateObject("scripting.dictionary")

Set Rg = Application.InputBox("请您框选拆分依据列!只能选择单列单元格区域!", Title:="提示", Type:=8)

tCol = Rg.Column

tRow = Val(Application.InputBox("请您输入总表标题行的行数?"))

If tRow = 0 Then MsgBox "您未输入标题行行数,程序退出!": Exit Sub

Set Rng = ActiveSheet.UsedRange

arr = Rng

tCol = tCol - Rng.Column + 1

aCol = UBound(arr, 2)

For i = tRow + 1 To UBound(arr)

If Not d.exists(arr(i, tCol)) Then

d(arr(i, tCol)) = i

Else

d(arr(i, tCol)) = d(arr(i, tCol)) & "," & i

End If

Next

For Each sht In Worksheets

If d.exists(sht.Name) Then sht.Delete

Next

kr = d.keys

For i = 0 To UBound(kr)

If kr(i) <> "" Then

r = Split(d(kr(i)), ",")

ReDim brr(1 To UBound(r) + 1, 1 To aCol)

k = 0

For x = 0 To UBound(r)

k = k + 1

For j = 1 To aCol

brr(k, j) = arr(r(x), j)

Next

Next

With Worksheets.Add(, Sheets(Sheets.Count))

.Name = kr(i)

.[a1].Resize(tRow, aCol) = arr

.[a1].Offset(tRow, 0).Resize(k, aCol) = brr

Rng.Copy

.[a1].PasteSpecial Paste:=xlPasteFormats, Operation:=xlNone, SkipBlanks:=False, Transpose:=False

.[a1].Select

End With

End If

Next

Sheets(1).Activate

Set d = Nothing

Erase arr: Erase brr

MsgBox "数据拆分完成!"

Application.ScreenUpdating = True

Application.DisplayAlerts = True

End Sub

第三步:按条件快速将总表数据拆分成多个工作表使用流程。首先我们需要在菜单栏中显示【开发工具】。显示【开发工具】详细操作流程请参照:PPT小技巧:如何把视频嵌入到PPT演示文稿中合并成一个文件?PPT和Excel操作流程基本一致。左键单击菜单栏中的【开发工具】选项卡,左键单击【代码】功能区中的【宏】按钮。

ad6353189ceeb8f6138543905348b676.png

第四步:左键单击选中【宏】对话框中的【Sheet1.NewSheets】后,左键单击【执行(R)】按钮。

8ef9fb2951d5a99724b20333f266e5fd.png

第五步:素材中拆分工作表的条件是【班级】,左键单击【A】列后,【提示】对话框中的文本框会自动生成单元格区域【$A:$A】,左键单击【确定】按钮即可进行下一步操作。备注:也可长按鼠标左键圈选单元格区域,在圈选单元格区域时,无蚂蚁线作为提示,圈选完成后请核对圈选区域是否正确。

cbc6430de876bd33b2face5c7be0d0a2.png

第六步:在【输入】对话框的文本框中,键入总表标题行的行数,素材中标题行的行数为【1】,所以键入的数字为【1】,键入完成后,左键单击【确定】按钮。拆分完成后会有【数据拆分完成!】的提示框,左键单击【确定】按钮即可完成总表的拆分。

24f4501faa7ca6bfdd8e073b1d40ea7c.png

第七步:按条件快速将总表数据拆分成多个工作表效果展示。

5f158fd8ce72ddc1661b3be2c3e461e3.png

至此,Microsoft Excel按条件快速将总表数据拆分成多个工作表操作流程已全部结束。知识改变命运,科技成就未来。希望这个小知识能给您的工作和生活带来更多的便捷。如有疑问或建议,请在下方留言。点击关注,有更多科技知识等着您,谢谢您的支持。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值