Go语言encoding/xml包支持XML序列化与反序列化,核心是xml标签用法:字段映射元素名、,attr表属性、,chardata捕获文本、,any捕获未知子元素、,omitempty忽略零值。

Go 语言的 encoding/xml 包提供了简洁、高效的 XML 序列化(marshal)和反序列化(unmarshal)能力,无需第三方依赖。核心在于结构体标签 xml: 的正确使用,以及理解默认行为与常见陷阱。
定义结构体并映射 XML 元素
XML 解析的关键是让 Go 结构体字段与 XML 节点一一对应。通过 xml 标签控制映射方式:
-
字段名默认映射为同名小写 XML 元素名(如
Name→) -
xml:"name"强制指定元素名 -
xml:"name,attr"表示该字段解析为 XML 属性(attribute) -
xml:",chardata"捕获文本内容(如中的Hello Hello) -
xml:",any"捕获未知子元素(需配合自定义 UnmarshalXML) -
xml:",omitempty"序列化时忽略零值字段
示例结构体:
type Person struct {XMLName xml.Name `xml:"person"`
ID int `xml:"id,attr"`
Name string `xml:"name"`
Email string `xml:"contact>email"`
Age int `xml:"age,omitempty"`
Tags []string `xml:"tag"`
}
反序列化:从 XML 字符串或 Reader 解析为结构体
使用 xml.Unmarshal 将 XML 数据转为 Go 结构体。支持 []byte、io.Reader(如 strings.NewReader 或文件流):
立即学习“go语言免费学习笔记(深入)”;
xmlData := `var p Person
err := xml.Unmarshal([]byte(xmlData), &p)
if err != nil {
log.Fatal(err)
}
// p.ID == 123, p.Name == "Alice", p.Tags == []string{"dev", "go"}
序列化:将结构体转为格式化 XML 字符串
用 xml.MarshalIndent 生成缩进可读的 XML;xml.Marshal 输出紧凑格式:
ID: 456,
Name: "Bob",
Email: "b@example.com",
Tags: []string{"ops", "cloud"},
}
data, err := xml.MarshalIndent(p, "", " ")
if err != nil {
log.Fatal(err)
}
fmt.Println(string(data))
// 输出含缩进的 XML,根元素为
处理嵌套、属性、注释与命名空间
复杂 XML 需注意细节:
- 嵌套结构用匿名或具名结构体字段,路径用
xml:"parent>child"或分层结构体 - XML 属性必须显式声明
,attr,否则会被忽略 - 注释(
)默认不解析;如需捕获,需实现UnmarshalXML方法 - 命名空间(如
)可通过xml.Name.Space访问,或在结构体字段中用xml:"rss xmlns,attr"提取 - 空元素(
)可映射为bool类型字段,但需确保 XML 值为"true"/"false"或按需自定义解析
不复杂但容易忽略










