Go 使用 encoding.xml 套件提供對 XML 和類 XML 格式的內建支援。
|
|
|

package main
|
|
import (
"encoding/xml"
"fmt"
)
|
Plant 將對應到 XML。類似於 JSON 範例,欄位標籤會包含編碼器和解碼器的指令。這裡我們使用了 XML 套件的一些特殊功能:XMLName 欄位名稱會決定用來代表這個結構的 XML 元素的名稱;id,attr 表示 Id 欄位是 XML 屬性,而不是巢狀元素。
|
type Plant struct {
XMLName xml.Name `xml:"plant"`
Id int `xml:"id,attr"`
Name string `xml:"name"`
Origin []string `xml:"origin"`
}
|
|
func (p Plant) String() string {
return fmt.Sprintf("Plant id=%v, name=%v, origin=%v",
p.Id, p.Name, p.Origin)
}
|
|
func main() {
coffee := &Plant{Id: 27, Name: "Coffee"}
coffee.Origin = []string{"Ethiopia", "Brazil"}
|
產生代表我們植物的 XML;使用 MarshalIndent 來產生更便於人類閱讀的輸出。
|
out, _ := xml.MarshalIndent(coffee, " ", " ")
fmt.Println(string(out))
|
要將通用 XML 標頭新增到輸出,請明確附加它。
|
fmt.Println(xml.Header + string(out))
|
使用 Unmarshal 來將 XML 形式的位元組串流解析為資料結構。如果 XML 格式有誤或無法對應到 Plant,將會傳回詳細的錯誤說明。
|
var p Plant
if err := xml.Unmarshal(out, &p); err != nil {
panic(err)
}
fmt.Println(p)
|
|
tomato := &Plant{Id: 81, Name: "Tomato"}
tomato.Origin = []string{"Mexico", "California"}
|
parent>child>plant 欄位標籤會告知編碼器將所有 plant 巢狀到 <parent><child>... 之下
|
type Nesting struct {
XMLName xml.Name `xml:"nesting"`
Plants []*Plant `xml:"parent>child>plant"`
}
|
|
nesting := &Nesting{}
nesting.Plants = []*Plant{coffee, tomato}
|
|
out, _ = xml.MarshalIndent(nesting, " ", " ")
fmt.Println(string(out))
}
|