我一直在尝试使用几种不同的方法来查找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
答案 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编辑器中,您会看到如下内容:
请注意,即使我将名称更改为Data
,左侧仍有Sheet1
。这就是我所说的代号。
可以通过两种方式引用Data
工作表:
Debug.Print Sheet1.Name
Debug.Print Sheets("Data").Name
两者都应该返回Data
可以找到有关工作表代码名称的更多讨论here。