sql >> Database teknologi >  >> RDS >> Mysql

GoLang - Vedvarende ved hjælp af ISO-8859-1 tegnsæt

Jeg ville følge instruktionerne:"Close er nødvendigt for at fjerne eventuelle resterende delvist oversatte tegn til outputtet." For eksempel,

package main

import (
    "bytes"
    "code.google.com/p/go-charset/charset"
    _ "code.google.com/p/go-charset/data"
    "fmt"
    "io/ioutil"
    "strings"
)

func toISO88591(utf8 string) (string, error) {
    buf := new(bytes.Buffer)
    w, err := charset.NewWriter("latin1", buf)
    if err != nil {
        return "", err
    }
    fmt.Fprintf(w, utf8)
    w.Close()
    return buf.String(), nil
}

func fromISO88591(iso88591 string) (string, error) {
    r, err := charset.NewReader("latin1", strings.NewReader(iso88591))
    if err != nil {
        return "", err
    }
    buf, err := ioutil.ReadAll(r)
    if err != nil {
        return "", err
    }
    return string(buf), nil
}

func main() {
    utfi := "£5 for Peppé"
    fmt.Printf("%q\n", utfi)
    iso, err := toISO88591(utfi)
    if err != nil {
        fmt.Println(err)
    }
    fmt.Printf("%q\n", iso)
    utfo, err := fromISO88591(iso)
    if err != nil {
        fmt.Println(err)
    }
    fmt.Printf("%q\n", utfo)
    fmt.Println(utfi == utfo)
}

Output:

"£5 for Peppé"
"\xa35 for Pepp\xe9"
"£5 for Peppé"
true



  1. Hvordan opretter man forbindelse til SQL Server-database fra JavaScript i browseren?

  2. MySQL Duplikatkolonnefejl kun når forespørgslen er pakket som underforespørgsel

  3. Kan jeg redigere mysqli_result-objekt i php?

  4. Er EXISTS mere effektiv end COUNT(*)>0?