在行为空时复制到“新工作表”



问题

当我遇到空白行时,我需要一个可以从工作表1复制到工作表[I]的宏。

样本数据

asdfasdf 1234
asdf 1234
gasdf 1234
asdf 1234 
asdf 1234 
fdas 1234
ds 1234
1234d 1234

结果

宏应该已经获取了该示例数据并创建了4张新图纸。每个分组都是自己的电子表格。

代码

我对VBA有点陌生,所以我并不总是理解代码,但我确实发现这段代码很管用。我对它的理解不足以使它发挥作用。

 Sub CreateNewWorksheets()
  Dim lLoop As Long, lLoopStop As Long
  Dim rMove As Range, wsNew As Worksheet
  Set rMove = ActiveSheet.UsedRange.Columns(1)
  lLoopStop = WorksheetFunction.CountIf(rMove, "Category")
  For lLoop = 1 To lLoopStop
  Set wsNew = Sheets.Add
  rMove.Find("Category", rMove.Cells(1, 1), xlValues, _
  xlPart, , xlNext, False).CurrentRegion.Cut _
  Destination:=wsNew.Cells(1, 1)
  wsNew.UsedRange.Columns.AutoFit
 Next lLoop
End Sub

还有另一个解决方案。。。

'Split File up by blank sections
Application.ScreenUpdating = False
For Each c In ActiveSheet.Range("A:C").SpecialCells(xlCellTypeConstants).Areas
    c.Copy Destination:=Worksheets.Add(After:=Sheets(Sheets.Count)).Range("A1")
Next c

这两项都不适用于我。

提前感谢

尝试一下:

Sub CreateNewWorksheets()
    Dim rngStart As Range
    Dim rngEnd As Range
    Set rngStart = Range("A1")
    If Len(rngStart.Text) = 0 Then Set rngStart = rngStart.End(xlDown)
    Do
        Select Case (Len(rngStart.Offset(1).Text) = 0)
            Case True:  Set rngEnd = rngStart
            Case Else:  Set rngEnd = rngStart.End(xlDown)
        End Select
        Range(rngStart, rngEnd).EntireRow.Copy Sheets.Add(After:=Sheets(Sheets.Count)).Range("A1")
        Set rngStart = rngEnd.End(xlDown)
    Loop While rngStart.Row < Rows.Count
    Set rngStart = Nothing
    Set rngEnd = Nothing
End Sub

最新更新