登录
首页 >  Golang >  Go问答

XML 通过字段名称中的索引解组动态响应

来源:stackoverflow

时间:2024-04-27 21:15:37 472浏览 收藏

“纵有疾风来,人生不言弃”,这句话送给正在学习Golang的朋友们,也希望在阅读本文《XML 通过字段名称中的索引解组动态响应》后,能够真的帮助到大家。我也会在后续的文章中,陆续更新Golang相关的技术文章,有好的建议欢迎大家在评论留言,非常感谢!

问题内容

我正在尝试解组“动态”xml 响应,但我不确定如何处理它。服务器响应相当大的响应,所以我不想两次解析响应。 xml 如下所示:

...
<nic_cnt>2</nic_cnt>
<ifindex1>eno1</ifindex1>
<ifindex2>eno2</ifindex2>
...

因此 nic_cnt 字段定义 ifindex 发生的次数。由于我不知道 ifindex 会发生多少次,因此我无法静态定义解组响应所需的结构字段。


解决方案


您可以使用带有 ,any xml 标记选项的切片来告诉 encoding/xml 包将任何 xml 标记放入其中。这记录在 xml.Unmarshal()

if the xml element contains a sub-element that hasn't matched any
   of the above rules and the struct has a field with tag ",any",
   unmarshal maps the sub-element to that struct field.

对于 <ifindexxx> 标记,请使用另一个包含类型为 xml.Namexmlname 字段的结构,因此,如果您需要仅过滤以 ifindex 开头的字段,则实际字段名称将可用。

让我们解析以下 xml:

<root>
    <nic_cnt>2</nic_cnt>
    <ifindex1>eno1</ifindex1>
    <ifindex2>eno2</ifindex2>
</root>

我们可以用以下方式对其进行建模:

type root struct {
    niccnt  int     `xml:"nic_cnt"`
    entries []entry `xml:",any"`
}

type entry struct {
    xmlname xml.name
    value   string `xml:",innerxml"`
}

解析它的示例代码:

var root root
if err := xml.unmarshal([]byte(src), &root); err != nil {
    panic(err)
}
fmt.printf("%+v", root)

输出(在 Go Playground 上尝试一下):

{niccnt:2 entries:[
    {xmlname:{space: local:ifindex1} value:eno1}
    {xmlname:{space: local:ifindex2} value:eno2}]}

请注意,root.entries 还将包含其他未映射的 xml 标记。如果您只关心以 ifindex 开头的标签,则可以通过以下方式“过滤”它们:

for _, e := range root.entries {
    if strings.hasprefix(e.xmlname.local, "ifindex") {
        fmt.println(e.xmlname.local, ":", e.value)
    }
}

如果 xml 还包含附加标签:

<other>something else</other>

输出将是(在 Go Playground 上尝试这个):

{NicCnt:2 Entries:[
    {XMLName:{Space: Local:ifindex1} Value:eno1}
    {XMLName:{Space: Local:ifindex2} Value:eno2}
    {XMLName:{Space: Local:other} Value:something else}]}
ifindex1 : eno1
ifindex2 : eno2

本篇关于《XML 通过字段名称中的索引解组动态响应》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>