问题
xml文件格式如下:
<?xml version="1.0" encoding="utf-8"?>
<meta><version>1924</version></meta>
<record><manifest>
<file><name>resatlas.rec</name><version>resn/v1921</version><md5>09080959b6fee8071eeb7c7c760da5ba</md5></file>
<file><name>resatlascomp.atlas</name><version>resn/v1234</version><md5>a6e0254c076318fd4cbd6140ca64f2b0</md5></file>
<file><name>resatlascomp.png</name><version>resn/v1</version><md5>c1990d9110d0cf21ed9404e671577fed</md5></file>
</manifest></record>
写了一下 encoding/xml
的代码发现,貌似只能获取一个根节点,否则会报错:
expected element type <record> but have <meta>
曲线救国 <解决方案> 解析多个根节点的xml文件
既然你不让我解析多个根节点, 那我就修改xml文件,让其只有一个根节点. 我读取xml文本内容到 bf22 []byte 里面,然后去掉头,在包裹上我的 document即可:
changed := string(bf22)
changed = strings.ReplaceAll(changed, "<?xml version="1.0" encoding="utf-8"?>", "")
changed = "<document>" + changed + "</document>"
最终定义的Xml go结构为:
type MetaVersion struct {
//XMLName xml.Name `xml:"meta"`
Version int `xml:"version"`
}
type FileVDetail struct {
//XMLName xml.Name `xml:"file"`
Name string `xml:"name"`
Version string `xml:"version"`
Md5 string `xml:"md5"`
}
type RecordType struct {
XMLName xml.Name `xml:"document"`
//<meta><version>1924</version></meta>
Meta MetaVersion `xml:"meta"`
//<record><manifest>
//<file><name>resatlas.rec</name><version>resn/v1921</version><md5>09080959b6fee8071eeb7c7c760da5ba</md5></file>
Files []FileVDetail `xml:"record>manifest>file"`
}
不得不说 , 这个 XMLName xml.Name
还是有点恶心的,侵入了我的代码结构.