Excel VBA查找匹配值的行号

时间:2015-08-24 19:17:52

标签: vba excel-vba excel

我一直在尝试使用几种不同的方法来查找bingo的行号(由星号列出并分隔),但似乎都没有。我究竟做错了什么?在所有情况下,我都试过寻找Bingo和" Bingo"。

Sub Find_Bingo()

Dim wb As Workbook
Dim ws As Worksheet
Dim FoundCell As Range
Set wb = ActiveWorkbook
Set ws = ActiveSheet

    Const WHAT_TO_FIND As String = "Bingo"

    Set FoundCell = ws.Range("A").Find(What:=WHAT_TO_FIND)
    If Not FoundCell Is Nothing Then
        MsgBox (WHAT_TO_FIND & " found in row: " & FoundCell.Row)
    Else
        MsgBox (WHAT_TO_FIND & " not found")
    End If

'************

    With Sheet1
        Set FoundCell = Cells.Find(What:=Bingo, After:=.Cells(1, 1), _
 LookIn:=xlValues, lookat:= xlPart, SearchOrder:=xlByRows, _ 
 SearchDirection:=xlNext, MatchCase:=False, SearchFormat:=False).Activate
    End With

'************

Set FoundCell = Sheets("Sheet1").Columns("E").Find(Bingo, ActiveSheet.Cells(2, 2), LookIn:=xlValue, lookat:=xlWhole)

'************

FoundCell = Range("A:M").Find(Bingo)

'************

FoundCell = Application.WorksheetFunction.Match(Bingo, Range("A1:A200"), 0)

'************

FoundCell = Worksheets("Sheet1").Columns(1).Find(Bingo).Row

'************

Range("A:A").Find(Bingo, Range("A1")).Row

'************

ActiveWorkbook.Worksheets("Sheet1").Columns(1).Find(Bingo).Select

'************
End Sub

1 个答案:

答案 0 :(得分:13)

首次将ws.Range("A")更改为ws.Range("A:A"),将搜索整个列a,如下所示:

Sub Find_Bingo()

        Dim wb As Workbook
        Dim ws As Worksheet
        Dim FoundCell As Range
        Set wb = ActiveWorkbook
        Set ws = ActiveSheet

            Const WHAT_TO_FIND As String = "Bingo"

            Set FoundCell = ws.Range("A:A").Find(What:=WHAT_TO_FIND)
            If Not FoundCell Is Nothing Then
                MsgBox (WHAT_TO_FIND & " found in row: " & FoundCell.Row)
            Else
                MsgBox (WHAT_TO_FIND & " not found")
            End If
End Sub

对于第二种方法,您使用Bingo作为变量而不是字符串文字。这是我将Option Explicit添加到所有代码模块顶部的一个很好的示例,因为当您尝试运行代码时,它会将您引导到此“变量”,该变量未定义且不打算成为变量。

此外,当您使用With...End With时,在引用.之前需要Cells期,因此Cells应为.Cells。这模仿了正常的限定行为(即Sheet1.Cells.Find ..)

Bingo更改为"Bingo"并将Cells更改为.Cells

With Sheet1
        Set FoundCell = .Cells.Find(What:="Bingo", After:=.Cells(1, 1), _
        LookIn:=xlValues, lookat:=xlPart, SearchOrder:=xlByRows, _
        SearchDirection:=xlNext, MatchCase:=False, SearchFormat:=False)
    End With

If Not FoundCell Is Nothing Then
        MsgBox ("""Bingo"" found in row " & FoundCell.Row)
Else
        MsgBox ("Bingo not found")
End If

更新

在我的

With Sheet1
    .....
End With

Sheet1是指工作表的代码名称,而不是工作表本身的名称。例如,假设我打开一个新的空白Excel工作簿。默认工作表只是Sheet1。我可以在代码中使用代码名Sheet1来引用它,或者我可以使用索引Sheets("Sheet1")来引用它。使用代号的好处是,如果更改工作表的名称,它不会改变。

继续这个例子,假设我将Sheet1重命名为Data。使用Sheet1将继续有效,因为代码名称不会更改,但现在使用Sheets("Sheet1")会返回错误,并且该语法必须更新为工作表的新名称,因此需要成为Sheets("Data")

在VB编辑器中,您会看到如下内容:

code object explorer example

请注意,即使我将名称更改为Data,左侧仍有Sheet1。这就是我所说的代号。

可以通过两种方式引用Data工作表:

Debug.Print Sheet1.Name
Debug.Print Sheets("Data").Name

两者都应该返回Data

可以找到有关工作表代码名称的更多讨论here