Avatar billede krummel Juniormester
28. maj 2013 - 18:45 Der er 2 kommentarer

VBA find - Cells.Find(What =

På faneblad "forside" i B2 har jeg et nummer.
På faneblad "data" skal jeg finde den række dette nummer står i.

Den vil ikke helt godtage dette:
What = Sheets("forside").Range("B2")
Hvad gør jeg fejl?
Fx What = "2345" virker fint, så der er noget galt med min reference til "forside"


Private Sub cmdDato1_Click()
Dim iRow As Long
Dim ws As Worksheet
Set ws = Worksheets("data")

iRow = ws.Cells.Find(What = Sheets("forside").Range("B2"), SearchOrder:=xlRows, _
    SearchDirection:=xlPrevious, LookIn:=xlValues).Row
Avatar billede krummel Juniormester
28. maj 2013 - 18:46 #1
Det er excel 2007 jeg bruger
Avatar billede supertekst Ekspert
28. maj 2013 - 23:57 #2
Alternativ:

...
...
    iRow = findRække(ActiveWorkbook.Sheets("forside"), "B1:B100", 2345)
...
End Sub
Private Function findRække(ark, område, id)
    With ark.Range(område)
        Set c = .Find(id, LookIn:=xlValues, LookAt:=xlWhole)
        If Not c Is Nothing Then
            findRække = c.Row
        Else
            findRække = 0
        End If
    End With
End Function
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Kurser inden for grundlæggende programmering

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester