Wiąz - Sznurek

Sekwencja znaków Unicode jest nazywana ciągiem. W Elm ciągi znaków są zawarte w "" podwójnych cudzysłowach . Ciąg to fragment tekstu, jak pokazano poniżej.

> "TutorialsPoint"
"TutorialsPoint" : String
> location = "Hyderabad" --variable
"Hyderabad" : String
> location
"Hyderabad" : String
>

Funkcje łańcuchowe

Poniżej podano niektóre typowe funkcje, których można używać do wykonywania zapytań lub manipulowania wartościami łańcuchów. Użyj REPL, aby wypróbować przykłady podane poniżej.

Sr. No metoda Opis
1 isEmpty: String -> Bool ciąg sprawdzeń jest pusty
2 rewers: String -> String odwraca ciąg wejściowy
3 długość: String -> Int zwraca liczbę całkowitą
4 append: String -> String -> String dołącza dwa ciągi i zwraca nowy ciąg
5 append: String -> Sconcat: List String -> String dołącza listę ciągów i zwraca nowy ciąg
6 split: String -> String -> List String dzieli ciąg wejściowy za pomocą podanego separatora, zwraca listę ciągów
7 plasterek: Int -> Int -> String -> String zwraca podłańcuch z podanym początkowym, końcowym indeksem i ciągiem wejściowym
8 zawiera: Ciąg -> Ciąg -> Bool zwraca prawdę, jeśli drugi ciąg zawiera pierwszy
9 toInt: String -> Result.Result String Int analizuje ciąg znaków na liczbę całkowitą
10 toInt: String -> Result.Result String Int analizuje ciąg znaków na liczbę całkowitą
11 toFloat: String -> Result.Result String Float analizuje ciąg znaków do float
12 fromChar: Char -> String tworzy ciąg z podanego znaku.
13 toList: String -> List Char konwertuje ciąg znaków na listę znaków
14 fromList: List Char -> String konwertuje listę znaków na String
15 toUpper: String -> String konwertuje ciąg wejściowy na wielkie litery
16 trim: String -> String pozbywa się białych znaków po obu stronach łańcucha.
17 filter: (Char -> Bool) -> String -> String filtruje zestaw znaków z ciągu wejściowego
18 map: (Char -> Char) -> String -> String przekształca każdy znak w ciągu wejściowym

jest pusty

Ta funkcja może służyć do określenia, czy ciąg jest pusty. Ta funkcja zwraca wartość True, jeśli podany ciąg jest pusty.

Składnia

String.isEmpty String_value

Aby sprawdzić podpis funkcji, wpisz w elm REPL -

> String.isEmpty
<function> : String -> Bool

Podpis funkcji pokazuje Bool jako typ zwracany, a typ wejściowy jako String -

Ilustracja

> String.isEmpty ""
True : Bool
> String.isEmpty "Tutorialspoint"
False : Bool
> location = "Hyderabad"
"Hyderabad" : String
> String.isEmpty location
False : Bool

odwrócić

Ta funkcja odwraca ciąg.

Składnia

String.reverse String_value

Aby sprawdzić podpis funkcji, wpisz w elm REPL -

> String.reverse
<function> : String -> String

Podpis funkcji wyświetla ciąg jako typ zwracany, a typ wejściowy jako ciąg -

Ilustracja

> String.reverse "TutorialsPoint"
"tnioPslairotuT" : String

długość

Ta funkcja zwraca długość łańcucha.

Składnia

String.length String_value

Aby sprawdzić podpis funkcji, wpisz w elm REPL -

> String.length
<function-> : String -> Int

Podpis funkcji pokazuje Int jako typ zwracany, a typ wejściowy jako String.

Ilustracja

> String.length "Mohtashim"
9 : Int

dodać

Ta funkcja zwraca nowy ciąg, dołączając dwa ciągi.

Składnia

String.append String_value1 String_value2

Aby sprawdzić podpis funkcji, wpisz w elm REPL -

> String.append
<function-> : String -> String -> String

Sygnatura pokazuje dwa parametry wejściowe typu String i jeden parametr wyjściowy typu String

Ilustracja

> String.append "Tutorials" "Point"
TutorialsPoint : String

concat

Ta funkcja zwraca nowy ciąg, łącząc wiele ciągów w jeden.

Składnia

String.concat [String1,String2,String3]

Aby sprawdzić podpis funkcji, wpisz w elm REPL -

> String.concat
<function> : List String -> String

Signature of pokazuje listę parametrów wejściowych typu String i typu zwracanego ciągu

Ilustracja

> String.concat ["Hello","Tutorials","Point"]
HelloTutorialsPoint : String

rozdzielać

Ta funkcja dzieli ciąg przy użyciu podanego separatora.

Składnia

String.split string_seperator String_value

Aby sprawdzić podpis funkcji, wpisz w elm REPL -

> String.split
<function> : String -> String -> List String

Podpis pokazuje dwa parametry wejściowe typu String i wyprowadza jako listę typu łańcuchowego.

Ilustracja

> String.split "," "Hello,Tutorials,Point"
["Hello","Tutorials","Point"] : List String

plasterek

Ta funkcja zwraca podłańcuch z podanym indeksem początkowym i końcowym. Indeksy ujemne pobierane są od końca listy. Wartość indeksu zaczyna się od zera.

Składnia

String.slice start_index end_index String_value

Aby sprawdzić podpis funkcji, wpisz w elm REPL -

> String.slice
<function> : Int -> Int -> String -> String

Podpis przedstawia trzy parametry wejściowe i jeden typ zwracany.

Ilustracja

> String.slice 0 13 "TutorialsPoint"
"TutorialsPoin" : String

zawiera

Ta funkcja zwraca wartość True, jeśli drugi ciąg zawiera pierwszy.

Składnia

String.contains string1 string2

Aby sprawdzić podpis funkcji, wpisz w elm REPL -

> String.contains
<function> : String -> String -> Bool

Sygnatura pokazuje zwracany typ bool i dwa parametry wejściowe

Ilustracja

> String.contains "Point" "TutorialsPoint"
True : Bool

toInt

Ta funkcja konwertuje ciąg znaków na int.

Składnia

String.toInt string_value

Aby sprawdzić podpis funkcji, wpisz w elm REPL -

> String.toInt
<function> : String -> Result.Result String Int

Ponieważ toInt może zwracać błąd, zwracanym typem jest Result, czyli String lub Int.

Ilustracja

> String.toInt "20"
Ok 20 : Result.Result String Int
> String.toInt "abc"
Err "could not convert string 'abc' to an Int" : Result.Result String Int

unosić

Ta funkcja konwertuje ciąg znaków na liczbę zmiennoprzecinkową.

Składnia

String.toFloat string_value

Aby sprawdzić podpis funkcji, wpisz w elm REPL -

> String.toFloat
<function> : String -> Result.Result String Float

Ponieważ toFloat może zwracać błąd, zwracanym typem jest Result, czyli String lub Float.

Ilustracja

> String.toFloat "20.50"
Ok 20.5 : Result.Result String Float
> String.toFloat "abc"
Err "could not convert string 'abc' to a Float" : Result.Result String Float

fromChar

Ta funkcja tworzy łańcuch z podanego znaku.

Składnia

String.fromChar character_value

Aby sprawdzić podpis funkcji wpisz następujący w elm REPL -

> String.fromChar
<function> : Char -> String

Podpis przedstawia ciąg jako typ zwracany, a dane wejściowe jako typ Char

Ilustracja

> String.fromChar 'c'
"c" : String

notować

Ta funkcja konwertuje ciąg na listę znaków.

Składnia

String.toList string_value

Aby sprawdzić podpis funkcji, wpisz w elm REPL -

> String.toList
<function> : String -> List Char

Sygnatury pokazują, że funkcja zwraca listę znaków i pobiera ciąg.

Ilustracja

> String.toList "tutorialspoint"
['t','u','t','o','r','i','a','l','s','p','o','i','n','t'] : List Char

fromList

Ta funkcja konwertuje listę znaków na łańcuch.

Składnia

String.fromList list_of_characters

Aby sprawdzić podpis funkcji, wpisz w elm REPL -

> String.fromList
<function> : List Char -> String

Sygnatury pokazują, że funkcja zwraca listę znaków i pobiera ciąg.

Ilustracja

> String.fromList ['h','e','l','l','o']
"hello" : String

toUpper

Ta funkcja konwertuje ciąg znaków na wielkie litery.

Składnia

String.toUpper String_value

Aby sprawdzić podpis funkcji, wpisz w elm REPL -

> String.toUpper
<function> : String -> String

Ilustracja

> String.toUpper "hello"
"HELLO" : String

obniżyć

Ta funkcja konwertuje ciąg znaków na małe litery.

Składnia

String.toLower String_value

Aby sprawdzić podpis funkcji, wpisz w elm REPL -

> String.toLower
<function> : String -> String

Ilustracja

> String.toLower "AbCd"
"abcd" : String

trym

Ta funkcja usuwa białe znaki po obu stronach łańcucha.

Składnia

String.trim String_value

Aby sprawdzić podpis funkcji, wpisz w elm REPL -

> String.trim
<function> : String -> String

Ilustracja

> String.trim "tutorialspoint "
"tutorialspoint" : String

filtr

Ta funkcja filtruje zestaw znaków z wejściowego ciągu znaków. Zachowaj tylko te postacie, które przejdą test.

Składnia

String.filter test_function string_value

Aby sprawdzić podpis funkcji, wpisz w elm REPL -

> String.filter
<function> : (Char -> Bool) -> String -> String

Podpis pokazuje, że filtr przyjmuje dwa parametry wejściowe i zwraca ciąg. Pierwszym parametrem jest funkcja, która ma dane wejściowe Char i zwraca wartość Bool.

Ilustracja

W tym przykładzie przekazujemy Char.isUpper jako parametr do metody filtrującej; zwraca wszystkie wielkie litery, jak pokazano poniżej.

> import Char
> String.filter Char.isUpper "abcDEF"
"DEF" : String

mapa

Ta funkcja przyjmuje ciąg znaków i przekształca każdy znak w ciągu.

Składnia

String.filter mapping_function string_value

Aby sprawdzić podpis funkcji, wpisz w elm REPL -

> String.map
<function> : (Char -> Char) -> String -> String

Ilustracja

Poniższy przykład zastępuje znak o znakiem @ -

> String.map (\c -> if c == 'o' then '@' else c) "TutorialsPoint"
"Tut@rialsP@int" : String