ホームページ > バックエンド開発 > Golang > XPath を使用せずに Go で XML データを走査して処理するにはどうすればよいですか?

XPath を使用せずに Go で XML データを走査して処理するにはどうすればよいですか?

Mary-Kate Olsen
リリース: 2024-11-30 15:40:10
オリジナル
326 人が閲覧しました

How Can I Traverse and Process XML Data in Go without Using XPath?

正確な Xpath を使用せずに Go で XML データをトラバースする

xml.UnMarshal を使用して XML を構造体にデコードする場合、動的処理の制限に遭遇する可能性があります。または階層データセット。これに対処するには、カスタム トラバーサル メカニズムを活用して、ノードとその子孫を柔軟な方法で処理することを検討してください。

実装

  1. 定義再帰的ノード構造体:

    type Node struct {
     XMLName xml.Name
     Content []byte `xml:",innerxml"`
     Nodes   []Node `xml:",any"`
    }
    ログイン後にコピー
  2. 再帰走査用のウォーク関数の作成:

    func walk(nodes []Node, f func(Node) bool) {
     for _, n := range nodes {
         if f(n) {
             walk(n.Nodes, f)
         }
     }
    }
    ログイン後にコピー

これ関数はノードのスライスを再帰的に走査し、指定された関数 f を次のように呼び出します。

  1. ノードの走査と処理:

上記のコンポーネントを組み合わせることで、次のように 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 サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート