정확한 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를 호출합니다. node.
위 구성 요소를 결합하면 다음과 같이 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!