Office: VBA- Zwei Begriffe mit ".Find" suchen

Helfe beim Thema VBA- Zwei Begriffe mit ".Find" suchen in Microsoft Excel Hilfe um das Problem gemeinsam zu lösen; HAllo, ich möchte in einem Bereich nach zwei Begriffen suchen. Mit einem Begriff bekomme ich das mit folgendem Code ohne Probleme hin. Set rngBereich... Dieses Thema im Forum "Microsoft Excel Hilfe" wurde erstellt von Marius82, 2. November 2012.

  1. Marius82 Erfahrener User

    VBA- Zwei Begriffe mit ".Find" suchen


    HAllo, ich möchte in einem Bereich nach zwei Begriffen suchen. Mit einem Begriff bekomme ich das mit folgendem Code ohne Probleme hin.

    Code:
    Set rngBereich = .Range(.Cells(lngZeile, 4), .Cells(1, 4)).Find("ZP04", lookat:=xlWhole, searchdirection:=xlPrevious).Rows
    Ich möchte aber nach zwei Begriffen suchen. Also entweder "ZP04" oder "ZP06". Wenn einer von den beiden begriffen gefunden wird soll rngBereich gefüllt werden.

    Geht das irgendwie mit .Find("ZP04","ZP06").... ?

    Danke
    Ich benutze Excel 2010
     
    Marius82, 2. November 2012
    #1
  2. Exl121150 Erfahrener User
    Hallo,

    mit folgendem Makro müsste eine Entweder-Oder-Suche möglich sein, wobei zuerst nach "ZP04" gesucht wird. Falls dieses nicht gefunden wird, erst dann wird nach "ZP06" gesucht.
    Code:
    Public Sub Suchen_EntwederOder()
      Dim lngZeile As Long
      Dim rngBereich As Range, Ws As Worksheet
      
      lngZeile = 10
      Set Ws = ActiveSheet
      With Ws.Range(.Cells(lngZeile, 4), .Cells(1, 4))
        Set rngBereich = .Find(What:="ZP04", LookIn:=xlValues, lookAt:=xlWhole, searchdirection:=xlPrevious)
        If rngBereich Is Nothing Then
          Set rngBereich = .Find(What:="ZP06", LookIn:=xlValues, lookAt:=xlWhole, searchdirection:=xlPrevious)
          If rngBereich Is Nothing Then
            MsgBox "Weder ZP04 noch ZP06 gefunden -> Abbruch"
            Exit Sub
          End If
        End If
        
      End With
      'rngBereich: enthält jetzt die Zelle, in der entweder "ZP04" oder "ZP06" enthalten ist (also maximal 1 Zelle):
      MsgBox "Fundstelle: " & rngBereich.Address
    End Sub
    
    
     
    Zuletzt bearbeitet: 2. November 2012
    Exl121150, 2. November 2012
    #2
  3. Beverly
    Beverly Erfahrener User
    Hi Marius,

    beides in einem Durchgang mittels Entweder-Oder als Suchkriterium finden geht nicht - verwende 2 unterschiedliche Variablen:

    Möglichkeit:
    Code:
    Sub Finden()
       Dim rngBereich1 As Range
       Dim rngBereich2 As Range
       Dim lngZeile As Long
       lngZeile = 100
       With ActiveSheet
          Set rngBereich1 = .Range(.Cells(lngZeile, 4), .Cells(1, 4)).Find("ZP04", lookat:=xlWhole, searchdirection:=xlPrevious).Rows
          Set rngBereich2 = .Range(.Cells(lngZeile, 4), .Cells(1, 4)).Find("ZP06", lookat:=xlWhole, searchdirection:=xlPrevious).Rows
          If Not rngBereich1 Is Nothing Then
             MsgBox "ZP04 gefunden in Zeile " & rngBereich1.Row
          End If
          If Not rngBereich2 Is Nothing Then
             MsgBox "ZP06 gefunden in Zeile " & rngBereich2.Row
          End If
       End With
       Set rngBereich1 = Nothing
       Set rngBereich2 = Nothing
    End Sub
    Bis später,
    Karin
     
    Beverly, 2. November 2012
    #3
Thema:

VBA- Zwei Begriffe mit ".Find" suchen

Die Seite wird geladen...
  1. VBA- Zwei Begriffe mit ".Find" suchen - Similar Threads - VBA Begriffe Find

  2. VBA in einer Zeile zu lang

    in Microsoft Excel Hilfe
    VBA in einer Zeile zu lang: Moin, mein VBA Code ist für eine Zeile zu lang. Kann mir einer helfen wie ich den auf 2 Zeilen aufteilen Kann? arrSchuhDaten = Array(Range("A6"), Range("F6"), Range("J6"), Range("A7"),...
  3. Listbox wird nicht breiter, Schriftgrösse ändert sich

    in Microsoft Excel Hilfe
    Listbox wird nicht breiter, Schriftgrösse ändert sich: Hallo, ich habe ein Formular dessen Breite ich mit der Maus ändern kann. Im Formular habe ich einen Rahmen und darin eine Listbox deren Breite an die Formularbreite angepasst wird....
  4. Kontrollkästchen aktivieren ohne VBA - wenn KK1 angekreuzt dann KK2 auch

    in Microsoft Excel Hilfe
    Kontrollkästchen aktivieren ohne VBA - wenn KK1 angekreuzt dann KK2 auch: Hallo zusammen, erstmal danke für all die Tipps und Kniffe, die ich ohne eigenen Thread gefunden und gelernt habe. Leider finde ich mein Thema nirgendwo... Aktuell habe ich zwei Spalten mit...
  5. Per Hyperlink ausgeblendetes Blatt einblenden

    in Microsoft Excel Hilfe
    Per Hyperlink ausgeblendetes Blatt einblenden: Hola ins Forum, ich bräuchte mal wieder eure Hilfe. Ich habe ein Tabellenblatt das mir als Register dient und wo Hyperlinks eingefügt sind um auf das dazugehörige Blatt zu springen. Diese Blätter...
  6. Bilder über VBA Größe und DPI ändern für Webshop

    in Microsoft Excel Hilfe
    Bilder über VBA Größe und DPI ändern für Webshop: Hallo Excel Spezialisten, Ich habe mir eine recht aufwendige Tabelle gebastelt, aus der ich Daten für meinen Webshop generiere und in einer .csv bereitstelle. Es werden neue Preislisten...
  7. VBA: Platzhalter ersetzen und evtl. leere Zeile einfügen

    in Microsoft Word Hilfe
    VBA: Platzhalter ersetzen und evtl. leere Zeile einfügen: Hallo zusammen, ich habe eine Word-Vorlage mit Platzhaltern, in die ich mit VBA Daten aus einer Excel-Datei einfüge (in eine Excel-Zeile schreibe ich alle Daten für ein neues Word-Dokument). So...
  8. VBA Wenn in Spalte B *Begriff* und in Spalte C *Leer* dann schreibe 5

    in Microsoft Excel Hilfe
    VBA Wenn in Spalte B *Begriff* und in Spalte C *Leer* dann schreibe 5: Hallo Leute, ich habe Probleme mit dem Erstellen eines Makros. Ich möchte gern eine Abfrage automatisieren. Ich habe in Spalte C verschiedene Zahlenwerte, 5, 10, oder 15 usw. Es kann aber...
  1. Diese Seite verwendet Cookies, um Inhalte zu personalisieren, diese deiner Erfahrung anzupassen und dich nach der Registrierung angemeldet zu halten.
    Auf dieser Website werden Cookies für die Zugriffsanalyse und Anzeigenmessung verwendet.
    Wenn du dich weiterhin auf dieser Seite aufhältst, akzeptierst du unseren Einsatz von Cookies.
    Information ausblenden