Lekcje modułu (2/5)
`strings` i `strconv`
strings i strconv to dwa pakiety, z których będziesz stale korzystać. Pierwsza manipuluje ciągami znaków (dzielenie, przycinanie, zamiana, wyszukiwanie); druga konwertuje pomiędzy ciągami znaków i typami podstawowymi (int, float, bool).
strings: funkcje, po które sięgasz każdego dnia
import "strings"
strings.ToUpper("ciao") // "CIAO"
strings.ToLower("CIAO") // "ciao"
strings.Contains("ciao mondo", "mo") // true
strings.HasPrefix("foo.txt", "foo") // true
strings.HasSuffix("foo.txt", ".txt") // true
strings.Index("ciao", "a") // 2 (or -1 if absent)
strings.Count("banana", "a") // 3
strings.Split("a,b,c", ",") // []string{"a","b","c"}
strings.SplitN("a,b,c,d", ",", 2) // []string{"a","b,c,d"}
strings.Join([]string{"a","b"}, "-") // "a-b"
strings.TrimSpace(" ciao\n") // "ciao"
strings.Trim("__ciao__", "_") // "ciao"
strings.ReplaceAll("aaa", "a", "b") // "bbb"
strings.Replace("aaa", "a", "b", 2) // "bba" (limit 2)Istnieją również warianty EqualFold do porównań bez uwzględniania wielkości liter bez przydzielania oraz Cut(s, sep) (before, after, found) do analizowania jednowierszowego.
key, val, ok := strings.Cut("name=Ada", "=")
// "name", "Ada", truestrings.Builder do połączenia w pętli
Konkatenacja s = s + "x" w pętli przydzielana jest w każdej iteracji (łańcuchy są niezmienne). W przypadku tekstu utworzonego w wielu krokach użyj strings.Builder:
var b strings.Builder
for i := 0; i < 1000; i++ {
b.WriteString("x")
}
out := b.String()Zamortyzowany przydział, żadnych bezużytecznych kopii.
strconv: ciąg znaków ↔ konwersja liczbowa/bool
import "strconv"
n, err := strconv.Atoi("42") // int from decimal
s := strconv.Itoa(42) // "42"
b, err := strconv.ParseBool("true")
// Generic versions with base and optional bit-size
i64, err := strconv.ParseInt("ff", 16, 64) // 255
u64, err := strconv.ParseUint("7", 10, 8) // 7
f, err := strconv.ParseFloat("3.14", 64) // 3.14
// Number → string
strconv.FormatInt(255, 16) // "ff"
strconv.FormatFloat(3.14, 'f', 2, 64) // "3.14"
strconv.FormatBool(true) // "true"Atoi/Itoa to ergonomiczne skróty; aby uzyskać precyzyjną kontrolę nad podstawą i rozmiarem, użyj ParseInt/FormatInt.
Obsługa błędów analizy
Atoi zwraca (int, error). Błąd prawie zawsze to *strconv.NumError i można go porównać za pomocą errors.Is z wartownikami strconv.ErrSyntax lub strconv.ErrRange:
n, err := strconv.Atoi(input)
switch {
case errors.Is(err, strconv.ErrSyntax):
return fmt.Errorf("input non numerico: %q", input)
case errors.Is(err, strconv.ErrRange):
return fmt.Errorf("numero fuori range: %q", input)
case err != nil:
return err
}
_ = nĆwiczenia
Podziel ciąg „a, b, c” na przecinku i wydrukuj powstały wycinek.
Rozwiązanie dostępne po 3 próbach
Przekonwertuj ciąg „42” na int za pomocą strconv.Atoi, obsłuż błąd i wydrukuj liczbę.
Rozwiązanie dostępne po 3 próbach
Jaki jest idiomatyczny sposób konwersji liczby całkowitej 42 na ciąg „42”?
s := ???(42)
// vogliamo s == "42"