[Excel VBA]如何使用VBA按行拆分Excel工作表

如何使用VBA按行拆分Excel工作表

在Excel中,按行拆分工作表并生成多个新工作表是一项实用的技能,尤其在处理大量数据时。以下是一个VBA代码示例,能帮助你轻松实现这一功能。

1. 代码说明

本代码会根据源工作表中每个姓名创建一个新工作表,工作表名称为姓名。

原始表格:

按姓名拆分后:

2. VBA代码

复制代码
Sub SplitSheetByRow()
    Dim ws As Worksheet
    Dim newWs As Worksheet
    Dim lastRow As Long
    Dim i As Long

    ' 获取当前工作表
    Set ws = ThisWorkbook.Sheets("姓名清单")
    
    ' 找到最后一行
    lastRow = ws.Cells(ws.Rows.Count, "A").End(xlUp).Row

    ' 循环每一行,从第二行开始
    For i = 2 To lastRow
        ' 创建新工作表
        Set newWs = ThisWorkbook.Sheets.Add(After:=ThisWorkbook.Sheets(ThisWorkbook.Sheets.Count))
        newWs.Name = ws.Cells(i, 1)
        
        ' 将当前行复制到新工作表
        ws.Rows(i).Copy Destination:=newWs.Rows(1)
    Next i
    
    MsgBox "拆分完成!", vbInformation
End Sub

3. 如何使用

  1. 打开Excel:启动Excel并打开你的工作簿。
  2. 打开VBA编辑器:按 ALT + F11 进入VBA编辑器。
  3. 插入模块:右键点击你的工作簿,选择"插入" > "模块"。
  4. 粘贴代码:将上述代码粘贴到模块窗口中。
  5. 运行代码:按 F5 或从菜单选择"运行"。

4. 注意事项

  • 确保原始工作表名称为"姓名清单"或根据需要进行修改。
  • 此代码会在工作簿中添加多个新工作表,请注意名称的唯一性。

5. 总结

使用VBA按行拆分Excel工作表,可以大大提高数据处理的效率。通过上述简单的代码,你可以快速生成所需的新工作表,节省了大量的手动操作时间。希望这篇文章能帮助你更好地利用Excel的功能!

相关推荐
远洪1 天前
excel 找出两列不同的数据
excel
pcplayer1 天前
非常好用的 Excel 读写控件
excel·delphi·office
Navicat中国1 天前
使用 Navicat 导入向导导入 Excel 数据时,系统提示导入成功,表中也能看到数据,但行数统计显示为 0,这是什么原因?
数据库·excel·导入
穿着内裤的外星人1 天前
触控精灵远程读写Excel步骤配置
excel
是孑然呀2 天前
【小记】excel vlookup一对多(第二篇)
excel
开开心心就好2 天前
专为视障人士设计的免费辅助工具
windows·计算机视觉·计算机外设·excel·散列表·推荐算法·csdn开发云
transformer_WSZ2 天前
excel两列数据绘制折线图
excel·折线图
蒋胜山2 天前
Excel 练习题(5)
经验分享·excel
Data-Miner2 天前
数以轻舟聚焦Excel-Agent场景:当AI做表工具学会说人话
人工智能·excel
夏日清风有你2 天前
Excel 中绘制散点图(Scatter Plot)
excel