В вашем коде есть конкретная строка, которая возвращает ошибку
xml.Unmarshal(byteValue, &articles)
Если вы измените ее на
err = xml.Unmarshal(byteValue, &articles)
if err != nil {
fmt.Println(err.Error())
}
Вы увидите сообщение об ошибке: xml: encoding "ISO-8859-1" declared but Decoder.CharsetReader is nil
,Рекомендуется всегда проверять наличие возвращаемых ошибок.
Чтобы это исправить, вы можете либо удалить атрибут кодирования (encoding="ISO-8859-1"
) из XML, либо немного изменить код своего демаршаллинга:
package main
import (
"encoding/xml"
"fmt"
"io"
"os"
"golang.org/x/text/encoding/charmap"
)
// Contains the array of articles in the dblp xml
type Dblp struct {
XMLName xml.Name `xml:"dblp"`
Dblp []Article `xml:"article"`
}
// Contains the article element tags and attributes
type Article struct {
XMLName xml.Name `xml:"article"`
Key string `xml:"key,attr"`
Year string `xml:"year"`
}
func main() {
xmlFile, err := os.Open("dblp.xml")
if err != nil {
fmt.Println(err)
}
fmt.Println("Successfully Opened TestDblp.xml")
// defer the closing of our xmlFile so that we can parse it later on
defer xmlFile.Close()
var articles Dblp
decoder := xml.NewDecoder(xmlFile)
decoder.CharsetReader = makeCharsetReader
err = decoder.Decode(&articles)
if err != nil {
fmt.Println(err)
}
for i := 0; i < len(articles.Dblp); i++ {
fmt.Println("Entered loop")
fmt.Println("get title: " + articles.Dblp[i].Key)
fmt.Println("get year: " + articles.Dblp[i].Year)
}
}
func makeCharsetReader(charset string, input io.Reader) (io.Reader, error) {
if charset == "ISO-8859-1" {
// Windows-1252 is a superset of ISO-8859-1, so should do here
return charmap.Windows1252.NewDecoder().Reader(input), nil
}
return nil, fmt.Errorf("Unknown charset: %s", charset)
}
запуск вышеуказанной программы приводит к:
Successfully Opened TestDblp.xml
Entered var
Entered loop
get title: journals/cacm/Gentry10
get year: 2010
Entered loop
get title: journals/cacm/Gentry10
get year: 2010