内容简介:今天在处理xml解析的时候,遇到一个动态处理的问题如下:输出如下
今天在处理xml解析的时候,遇到一个动态处理的问题如下:
type Example struct { XMLName xml.Name `xml:"example"` A string `xml:"a"` Param interface{} `xml:"param"` }
Param
的结构不固定,但是xml又没有json的 RawMessage
类似,要实现动态解析多有不便,但是还是有方法
package main import ( "encoding/xml" "fmt" ) var rawXML1 = []byte(`<example> <a> hello </a> <param> <x>1</x> <y>2</y> </param> </example>`) var rawXML2 = []byte(`<example> <a> hello </a> <param> <m>3</m> <n>4</n> </param> </example>`) type Example struct { XMLName xml.Name `xml:"example"` A string `xml:"a"` Param interface{} `xml:"param"` } type Pair1 struct { X string `xml:"x"` Y string `xml:"y"` } type Pair2 struct { M int `xml:"m"` N int `xml:"n"` } func main() { // rawmessage with interface { var a Example err := xml.Unmarshal(rawXML1, &a) println(err == nil) fmt.Printf("a is:%+v\n", a.Param) } // rawmessage with interface assignment value { var a Example var p1 Pair1 a.Param = p1 err := xml.Unmarshal(rawXML1, &a) println(err == nil) fmt.Printf("a is:%+v\n", a.Param) } // rawmessage with interface assignment pointer { var a Example var p1 Pair1 a.Param = &p1 err := xml.Unmarshal(rawXML1, &a) println(err == nil) fmt.Printf("a is:%+v\n", a.Param) } // rawmessage with interface assignment pointer { var a Example var p2 Pair2 a.Param = &p2 err := xml.Unmarshal(rawXML2, &a) println(err == nil) fmt.Printf("a is:%+v", a.Param) } }
输出如下
true a is:<nil> true a is:{X: Y:} true a is:&{X:1 Y:2} true a is:&{M:3 N:4}
可以通过指针赋值的方式让xml实现动态解析,这里必须传指针, 因为这里实现的是一个类似于 RawMessage
的Unmarshal过程。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- btrace动态追踪技术解析
- 成本计算引擎动态规则解析技术详解
- MyBatis使用动态表或列代码解析
- 基于CoreDNS和etcd实现动态域名解析
- 使用Go语言解析动态JSON格式的方法
- Leetcode动态规划之PHP解析(120. Triangle)
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
计算机算法设计与分析
王晓东 / 电子工业出版社 / 2007-5 / 29.50元
《计算机算法设计与分析(第3版)》为普通高等教育“十一五”国家级规划教材,是计算机专业核心课程“算法设计与分析”教材。全书以算法设计策略为知识单元,系统介绍计算机算法的设计方法与分析技巧。主要内容包括:算法概述、递归与分治策略、动态规划、贪心算法、回溯法、分支限界法、随机化算法、线性规划与网络流、NP完全性理论与近似算法等。书中既涉及经典与实用算法及实例分析,又包括算法热点领域追踪。 为突出......一起来看看 《计算机算法设计与分析》 这本书的介绍吧!