用于删除不需要的内容的宏

时间:2018-05-31 12:54:38

标签: excel vba excel-vba

我正在尝试创建一个宏代码,我可以从VBA按下播放,当条件满足时,它会删除整行。我想要代码寻找的关键搜索是" PEDS"但需要注意的重要一点是,PEDS后面有数字(即PEDS1234),这些数字几乎就像一个变量和变化。

我可以帮助我,因为我被困在这上面了。

我创建的当前代码就像过滤器一样,不会自动删除数据。

Option Explicit

Sub KillRows()

    Dim MyRange As Range, DelRange As Range, C As Range
    Dim MatchString As String, SearchColumn As String, ActiveColumn As String
    Dim FirstAddress As String, NullCheck As String
    Dim AC

     'Extract active column as text
    AC = Split(ActiveCell.EntireColumn.Address(, False), ":")
    ActiveColumn = AC(0)

    SearchColumn = InputBox("Enter Search Column - press Cancel to exit sub", "Row Delete Code", ActiveColumn)

    On Error Resume Next
    Set MyRange = Columns(SearchColumn)
    On Error GoTo 0

     'If an invalid range is entered then exit
    If MyRange Is Nothing Then Exit Sub

    MatchString = InputBox("Enter Search string", "Row Delete Code", ActiveCell.Value)
    If MatchString = "" Then
        NullCheck = InputBox("Do you really want to delete rows with empty cells?" & vbNewLine & vbNewLine & _
        "Type Yes to do so, else code will exit", "Caution", "No")
        If NullCheck <> "Yes" Then Exit Sub
    End If

    Application.ScreenUpdating = False

     'to match the WHOLE text string
    Set C = MyRange.Find(What:=MatchString, After:=MyRange.Cells(1), LookIn:=xlValues, Lookat:=xlWhole)
     'to match a PARTIAL text string use this line
     'Set C = MyRange.Find(What:=MatchString, After:=MyRange.Cells(1), LookIn:=xlValues, Lookat:=xlpart)
     'to match the case and of a WHOLE text string
     'Set C = MyRange.Find(What:=MatchString, After:=MyRange.Cells(1), LookIn:=xlValues, Lookat:=xlWhole, MatchCase:=True)

    If Not C Is Nothing Then
        Set DelRange = C
        FirstAddress = C.Address
        Do
            Set C = MyRange.FindNext(C)
            Set DelRange = Union(DelRange, C)
        Loop While FirstAddress <> C.Address
    End If

     'If there are valid matches then delete the rows
    If Not DelRange Is Nothing Then DelRange.EntireRow.Delete

    Application.ScreenUpdating = True

End Sub

1 个答案:

答案 0 :(得分:1)

Option Explicit

Sub KillRows()

    Dim MyRange As Range, DelRange As Range, C As Range
    Dim MatchString As String, SearchColumn As String, ActiveColumn As String
    Dim FirstAddress As String, NullCheck As String
    Dim AC

    SearchColumn = "A" 'This is a new line    
    Set MyRange = Columns(SearchColumn)
    MatchString = "PEDS"

    Application.ScreenUpdating = False

     'to match a PARTIAL text string use this line
     Set C = MyRange.Find(What:=MatchString, After:=MyRange.Cells(1), LookIn:=xlValues, Lookat:=xlpart)

    If Not C Is Nothing Then
        Set DelRange = C
        FirstAddress = C.Address
        Do
            Set C = MyRange.FindNext(C)
            Set DelRange = Union(DelRange, C)
        Loop While FirstAddress <> C.Address
    End If

     'If there are valid matches then delete the rows
    If Not DelRange Is Nothing Then DelRange.EntireRow.Delete

    Application.ScreenUpdating = True

End Sub

你可以更多地清理你的代码。但这是一个开始,应该有效。

顺便说一句:谷歌的代码没有错。这是一种很好的学习方式。这也是我开始的方式......谷歌是你最好的朋友。