use*_*812 1 excel vba excel-vba excel-formula
现在我设法让这段代码在我的活动表中运行良好:
Sub Deletecells()
   Dim ws As Worksheet
     For Each ws In Worksheets
       Last = Cells(Rows.Count, "A").End(xlUp).Row
        For i = Last To 1 Step -1
          If (Cells(i, "A").Value) = "DELETE" Then
           Cells(i, "A").EntireRow.Delete
          End If
        Next i
   Next ws
End Sub
但我只能在一张表格中运行它(我将宏放入其中的表格),那么如何修改代码以便它可以在工作簿中的所有工作表中运行?谢谢!
小智 6
使用With ... End With块为所有Cell和Rows调用提供父工作表引用(转换为.Cells和.Rows以传递引用).
Sub Deletecells()
   Dim ws As Worksheet, last as long
   For Each ws In Worksheets
     with ws
       Last = .Cells(.Rows.Count, "A").End(xlUp).Row
        For i = Last To 1 Step -1
          If ucase(.Cells(i, "A").Value) = "DELETE" Then
            .Cells(i, "A").EntireRow.Delete
          End If
        Next i
     end with
   Next ws
End Sub
| 归档时间: | 
 | 
| 查看次数: | 30 次 | 
| 最近记录: |