Dela via


Funktionerna EndsWith och StartsWith

Gäller: Arbetsyteappar Datorflöden Dataverse formelkolumner Modellbaserade appar Power Pages Power Platform CLI

Testar om en textsträng börjar eller slutar med en annan textsträng.

Beskrivning

Funktionen EndsWith testar om en textsträng slutar med en annan.

Funktionen StartsWith testar om en textsträng börjar med en annan.

För båda funktionerna är testerna skiftlägesokänsliga om serverdelens datakälla stöder det som standard. Till exempel har samlingar, Dataverse, SharePoint och SQL Server stöd för skiftlägesokänslighet som standard. Oracle gör det inte. Returvärdet för båda är ett booleskt värde, true eller false.

Använd EndsWith och StartsWith med funktion Filter för att söka efter data i ditt program. Du kan också använda operatorn i eller funktionen Search för att titta var som helst inom textsträngar, inte bara i början eller slutet. Ditt val av funktioner beror på dina behov för ditt program och vilken funktion som kan delegeras för en viss datakälla. Om någon av dessa funktioner inte kan delegeras, visas en delegeringsvarning vid redigeringen för att varna dig om den här begränsningen.

Syntax

EndsWith( Text, EndText )

  • Text – obligatoriskt. Texten som ska testas.
  • EndText – obligatoriskt. Texten som ska sökas efter i slutet av Text. Om EndText är en tom sträng, EndsWith returnerar true.

StartsWith( Text, StartText )

  • Text – obligatoriskt. Texten som ska testas.
  • StartText – obligatoriskt. Texten som ska sökas efter i början av Text. Om StartText är en tom sträng, StartsWith returnerar true.

Exempel

Formel Beskrivning Resultat
EndsWith( "Hello World", "world" ) Kontrollerar om "Hello, World" slutar med "world". Testet är skiftlägesokänsligt. true
EndsWith( "Good bye", "good" ) Kontrollerar om "Good bye" slutar med "good". EndText-argumentet (”good”) visas i texten men inte i slutet. false
EndsWith( "Always say hello", "hello" ) Testar om "Always say hello" slutar med "hello". true
EndsWith( "Bye bye", "" ) Testar om ”Bye bye” slutar med en tom textsträng (Len returnerar 0). För att underlätta dess användning i Filter-uttryck har EndsWith definierats för att returnera true i det här fallet. true
Formel Beskrivning Resultat
StartsWith ("Hello World", "Hello") Testar om "Hello World" börjar med "hello". Testet är skiftlägesokänsligt. true
StartsWith( "Good bye", "hello" ) Testar om "Good bye" börjar med "hello". false
StartsWith( "Always say hello", "hello" ) Testar om "Always say hello" börjar med "hello". Även om "hello" visas i texten, visas det inte i början. false
StartsWith( "Bye bye", "" ) Testar om ”Bye bye” börjar med en tom textsträng (Len returnerar 0). För att underlätta dess användning i Filter-uttryck har StartsWith definierats för att returnera true i det här fallet. true

Användarupplevelsen för sökning

I många program kan du skriva ett eller flera tecken i en sökruta för att filtrera en lista med poster i en stor datauppsättning. När du skriver visar listan endast de poster som matchar sökvillkoren.

Exemplen i resten av det här avsnittet visar resultaten av en sökning av en kundlista som innehåller dessa data:

Exempel på kundlista.

Om du vill skapa den här datakällan som en samling skapar du först en Button-kontroll och ställer in dess egenskap OnSelect på följande formel:

ClearCollect(Customers, Table({ Name: "Fred Garcia", Company: "Northwind Traders" }, { Name: "Cole Miller", Company: "Contoso" }, { Name: "Glenda Johnson", Company: "Contoso" }, { Name: "Mike Collins", Company: "Adventure Works" }, { Name: "Colleen Jones", Company: "Adventure Works" }) )

Precis som i det här exemplet kan du visa en lista med poster i en gallerikontroll längst ned på skärmen. Nära toppen på skärmen kan du lägga till en Text Input-kontroll som heter SearchInput så att användarna kan ange vilka poster som intresserar dem.

Kundernas galleri.

När användaren skriver tecken i SearchInput, filtreras resultaten i galleriet automatiskt. I det här fallet har galleriet konfigurerats för att visa poster där kundens namn (inte namnet på företaget) börjar med teckenföljden i SearchInput. Om användaren skriver co i sökrutan, visar galleriet följande resultat:

Kundgalleri med sökning.

Om du vill filtrera efter kolumnen Name ställer du in gallerikontrollens egenskap Items på någon av följande formler:

Formel Beskrivning Resultat
Filter(Customers, StartsWith(Name, SearchInput.Text)) Filtrerar datakällan Customers efter poster där söksträngen visas i början av Name-kolumnen. Testet är skiftlägesokänsligt. Om användaren skriver co i sökrutan, visar galleriet Colleen Jones och Cole Miller. Galleriet visar inte Mike Collins eftersom Name-kolumnen för den posten inte börjar med söksträngen. Exempel på StartsWith.
Filter(Customers, SearchInput.Text in Name) Filtrerar datakällan Customers för poster där söksträngen visas någonstans i kolumnen Name. Testet är skiftlägesokänsligt. Om användaren skriver co i sökrutan, visar galleriet Colleen Jones,Cole Miller, och Mike Collins eftersom söksträngen finns någonstans i kolumnen Namn för alla dessa poster. Exempel på SearchInput.Text i namn.
Search( Customers, SearchInput.Text, "Name" ) Ungefär som att använda operatorn in, så söker funktionen Search efter en matchning var som helst inom kolumnen Name för varje post. Observera att du måste skriva kolumnnamnet med dubbla citattecken. Exempel på SearchInput.Text med namn.

Du kan utöka din sökning att inkludera Company-kolumnen utöver Name-kolumnen:

Formel Beskrivning Resultat
Filter( Customers, StartsWith( Name, SearchInput.Text ) || StartsWith( Company, SearchInput.Text ) ) Filtrerar datakällan Customers för poster där antingen Name-kolumnen eller Company-kolumnen börjar med söksträngen (t.ex. co). Operatorn || operatorn är true om någon av StartsWith-funktionerna är true. Filtrera med StartsWith.
Filter( Customers, SearchInput.Text in Name || SearchInput.Text in Company ) Filtrerar datakällan Customers för poster där antingen Name-kolumnen eller Company-kolumnen innehåller söksträngen (t.ex. co) var som helst inom sig. Filtrera med söktext i namn.
Search( Customers, SearchInput.Text, "Name", "Company" ) Ungefär som att använda in-operatorn så söker Search-funktionen igenom datakällan Customers för poster där antingen Name-kolumnen eller Company-kolumnen innehåller söksträngen (t.ex. co) var som helst inom sig. Search-funktionen är lättare att läsa och skriva än Filter om du vill ange flera kolumner och flera in-operatorer. Observera att du måste skriva kolumnnamnen med dubbla citattecken. Filtrera med söktext i namn, företag.