Sdílet prostřednictvím


ListBox.FindStringExact Metoda

Definice

Vyhledá první položku, ListBox která přesně odpovídá zadanému řetězci.

Přetížení

FindStringExact(String)

Najde první položku v ListBox zadaném řetězci, která přesně odpovídá zadanému řetězci.

FindStringExact(String, Int32)

Najde první položku v ListBox zadaném řetězci, která přesně odpovídá zadanému řetězci. Hledání začíná na konkrétním počátečním indexu.

FindStringExact(String)

Najde první položku v ListBox zadaném řetězci, která přesně odpovídá zadanému řetězci.

public:
 int FindStringExact(System::String ^ s);
public int FindStringExact (string s);
member this.FindStringExact : string -> int
Public Function FindStringExact (s As String) As Integer

Parametry

s
String

Text, který chcete vyhledat.

Návraty

Int32

Nalezený index na základě nuly první položky; vrátí, ListBox.NoMatches pokud nebyla nalezena žádná shoda.

Příklady

Následující příklad kódu ukazuje, jak použít metodu ListBox.FindStringExact ListBox pro vyhledávání ovládacího prvku pro položku, která přesně odpovídá zadanému řetězci. Pokud nejsou nalezeny žádné položky, které odpovídají vyhledávacímu řetězci, FindStringExact vrátí hodnotu -1 a příklad zobrazí MessageBoxhodnotu . Pokud se najde položka, která odpovídá vyhledávacímu textu, použije SetSelected příklad metodu k výběru položky v objektu ListBox.

private:
   void FindMySpecificString( String^ searchString )
   {
      // Ensure we have a proper string to search for.
      if ( searchString != String::Empty )
      {
         // Find the item in the list and store the index to the item.
         int index = listBox1->FindStringExact( searchString );

         // Determine if a valid index is returned. Select the item if it is valid.
         if ( index != ListBox::NoMatches )
                  listBox1->SetSelected( index, true );
         else
                  MessageBox::Show( "The search string did not find any items in the ListBox that exactly match the specified search string" );
      }
   }
private void FindMySpecificString(string searchString)
{
   // Ensure we have a proper string to search for.
   if (!string.IsNullOrEmpty(searchString))
   {
      // Find the item in the list and store the index to the item.
      int index = listBox1.FindStringExact(searchString);
      // Determine if a valid index is returned. Select the item if it is valid.
      if (index != ListBox.NoMatches)
         listBox1.SetSelected(index,true);
      else
         MessageBox.Show("The search string did not find any items in the ListBox that exactly match the specified search string");
   }
}
Private Sub FindMySpecificString(ByVal searchString As String)
   ' Ensure we have a proper string to search for.
   If searchString <> String.Empty Then
      ' Find the item in the list and store the index to the item.
      Dim index As Integer = listBox1.FindStringExact(searchString)
      ' Determine if a valid index is returned. Select the item if it is valid.
      If index <> ListBox.NoMatches Then
         listBox1.SetSelected(index, True)
      Else
         MessageBox.Show("The search string did not find any items in the ListBox that exactly match the specified search string")
      End If
   End If
End Sub

Poznámky

Hledání prováděné touto metodou nerozlišuje malá a malá písmena. Hledání hledá přesnou shodu se slovy zadanými v parametru vyhledávacího řetězce. s Tuto metodu můžete použít k vyhledání první položky, která odpovídá zadanému řetězci. Pak můžete provádět úlohy, jako je odebrání položky, která obsahuje hledaný text, pomocí Remove metody nebo změnou textu položky. Jakmile najdete zadaný text, můžete ListBoxpoužít verzi FindStringExact metody, která poskytuje parametr pro určení počátečního indexu v rámci ListBoxsouboru . Pokud chcete místo přesné shody slov provést částečné hledání slov, použijte metodu FindString .

Viz také

Platí pro

FindStringExact(String, Int32)

Najde první položku v ListBox zadaném řetězci, která přesně odpovídá zadanému řetězci. Hledání začíná na konkrétním počátečním indexu.

public:
 int FindStringExact(System::String ^ s, int startIndex);
public int FindStringExact (string s, int startIndex);
member this.FindStringExact : string * int -> int
Public Function FindStringExact (s As String, startIndex As Integer) As Integer

Parametry

s
String

Text, který chcete vyhledat.

startIndex
Int32

Index položky založený na nule před první položkou, která se má prohledávat. Nastavte na zápornou hodnotu (-1) a vyhledejte ji od začátku ovládacího prvku.

Návraty

Int32

Nalezený index na základě nuly první položky; vrátí, ListBox.NoMatches pokud nebyla nalezena žádná shoda.

Výjimky

Parametr startIndex je menší než nula nebo větší než nebo rovno hodnotě Count vlastnosti ListBox.ObjectCollection třídy.

Příklady

Následující příklad kódu ukazuje, jak použít metodu FindStringExact pro vyhledávání všech položek v přesně odpovídající zadaném vyhledávacím ListBox textu. Příklad používá verzi FindStringExact metody, která umožňuje zadat počáteční vyhledávací index, ze kterého se má provádět průběžné vyhledávání všech položek v souboru ListBox. Příklad také ukazuje, jak určit, kdy FindStringExact metoda začne hledat z horní části seznamu, jakmile dosáhne dolní části seznamu položek, aby se zabránilo rekurzivnímu vyhledávání. Jakmile jsou položky nalezeny v souboru ListBox, jsou vybrány pomocí SetSelected metody.

private:
   void FindAllOfMyExactStrings( String^ searchString )
   {
      // Set the SelectionMode property of the ListBox to select multiple items.
      listBox1->SelectionMode = SelectionMode::MultiExtended;

      // Set our intial index variable to -1.
      int x = -1;

      // If the search string is empty exit.
      if ( searchString->Length != 0 )
      {
         // Loop through and find each item that matches the search string.
         do
         {
            // Retrieve the item based on the previous index found. Starts with -1 which searches start.
            x = listBox1->FindStringExact( searchString, x );

            // If no item is found that matches exit.
            if ( x != -1 )
            {
               // Since the FindStringExact loops infinitely, determine if we found first item again and exit.
               if ( listBox1->SelectedIndices->Count > 0 )
               {
                  if ( x == listBox1->SelectedIndices[ 0 ] )
                                    return;
               }

               // Select the item in the ListBox once it is found.
               listBox1->SetSelected( x, true );
            }
         }
         while ( x != -1 );
      }
   }
private void FindAllOfMyExactStrings(string searchString)
{
   // Set the SelectionMode property of the ListBox to select multiple items.
   listBox1.SelectionMode = SelectionMode.MultiExtended;
   
   // Set our intial index variable to -1.
   int x =-1;
   // If the search string is empty exit.
   if (searchString.Length != 0)
   {
      // Loop through and find each item that matches the search string.
      do
      {
         // Retrieve the item based on the previous index found. Starts with -1 which searches start.
         x = listBox1.FindStringExact(searchString, x);
         // If no item is found that matches exit.
         if (x != -1)
         {
            // Since the FindStringExact loops infinitely, determine if we found first item again and exit.
            if (listBox1.SelectedIndices.Count > 0)
            {
               if (x == listBox1.SelectedIndices[0])
                  return;
            }
            // Select the item in the ListBox once it is found.
            listBox1.SetSelected(x,true);
         }
      }while(x != -1);
   }
}
Private Sub FindAllOfMyExactStrings(ByVal searchString As String)
   ' Set the SelectionMode property of the ListBox to select multiple items.
   ListBox1.SelectionMode = SelectionMode.MultiExtended

   ' Set our intial index variable to -1.
   Dim x As Integer = -1
   ' If the search string is empty exit.
   If searchString.Length <> 0 Then
      ' Loop through and find each item that matches the search string.
      Do
         ' Retrieve the item based on the previous index found. Starts with -1 which searches start.
         x = ListBox1.FindStringExact(searchString, x)
         ' If no item is found that matches exit.
         If x <> -1 Then
            ' Since the FindStringExact loops infinitely, determine if we found first item again and exit.
            If ListBox1.SelectedIndices.Count > 0 Then
               If x = ListBox1.SelectedIndices(0) Then
                  Return
               End If
            End If
            ' Select the item in the ListBox once it is found.
            ListBox1.SetSelected(x, True)
         End If
      Loop While x <> -1
   End If
End Sub

Poznámky

Hledání prováděné touto metodou nerozlišuje malá a malá písmena. Hledání hledá slova, která přesně odpovídají zadanému parametru vyhledávacího řetězce. s Tuto metodu můžete použít k vyhledání první položky, která odpovídá zadanému řetězci v zadaném počátečním indexu v seznamu položek pro danou ListBoxpoložku . Pak můžete provádět úlohy, jako je odebrání položky obsahující hledaný text pomocí Remove metody nebo změna textu položky. Tato metoda se obvykle používá po volání pomocí verze této metody, která nezadá počáteční index. Jakmile se v seznamu najde počáteční položka, tato metoda se obvykle používá k vyhledání dalších instancí hledaného textu zadáním pozice indexu v startIndex parametru položky po první nalezené instanci vyhledávacího textu. Pokud chcete místo přesné shody slov provést částečné hledání slov, použijte metodu FindString .

Poznámka

Když hledání dosáhne dolní části ListBox, bude pokračovat v hledání z horní části ListBox zpět na položku určenou parametrem startIndex .

Viz také

Platí pro