正確な Xpath を使用せずに Go で XML データをトラバースする
xml.UnMarshal を使用して XML を構造体にデコードする場合、動的処理の制限に遭遇する可能性があります。または階層データセット。これに対処するには、カスタム トラバーサル メカニズムを活用して、ノードとその子孫を柔軟な方法で処理することを検討してください。
実装
定義再帰的ノード構造体:
type Node struct { XMLName xml.Name Content []byte `xml:",innerxml"` Nodes []Node `xml:",any"` }
再帰走査用のウォーク関数の作成:
func walk(nodes []Node, f func(Node) bool) { for _, n := range nodes { if f(n) { walk(n.Nodes, f) } } }
これ関数はノードのスライスを再帰的に走査し、指定された関数 f を次のように呼び出します。
上記のコンポーネントを組み合わせることで、次のように XML データを走査してノードを処理できます。 :
// Create a slice of nodes from your XML data nodes := []Node{} // Recursively walk the nodes walk(nodes, func(n Node) bool { // Process the node here (e.g., check type, access attributes) return true })
の例属性
トラバーサルに属性を含めるには、Node 構造体とその UnmarshalXML メソッドを変更します。
type Node struct { XMLName xml.Name Attrs []xml.Attr `xml:",any,attr"` Content []byte `xml:",innerxml"` Nodes []Node `xml:",any"` } func (n *Node) UnmarshalXML(d *xml.Decoder, start xml.StartElement) error { n.Attrs = start.Attr type node Node return d.DecodeElement((*node)(n), &start) }
結論
これを利用する再帰的トラバーサル アプローチにより、XML データを効率的にトラバースして処理できます。特定の Xpath。これにより柔軟性が向上し、動的または可変の XML 構造を簡単に処理できるようになります。
以上がXPath を使用せずに Go で XML データを走査して処理するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。