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