> 백엔드 개발 > C++ > XElement를 사용하여 XML 문서를 만들 때 네임스페이스와 접두사를 올바르게 처리하는 방법은 무엇입니까?

XElement를 사용하여 XML 문서를 만들 때 네임스페이스와 접두사를 올바르게 처리하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-12-31 11:46:10
원래의
523명이 탐색했습니다.

How to Correctly Handle Namespaces and Prefixes When Creating XML Documents with XElement?

XElement 네임스페이스: 종합 가이드

노드 접두사가 있는 XML 문서 생성

XElement를 사용하여 XML 문서를 생성할 때 네임스페이스 접두사를 올바르게 처리하는 것이 중요합니다. 접두사가 있는 요소를 직접 생성하려고 시도하면(예: new XElement("sphinx:docset")) 예외가 발생합니다.

네임스페이스를 사용한 솔루션

LINQ to XML은 이에 대한 우아한 솔루션을 제공합니다.

XNamespace ns = "sphinx";
XElement element = new XElement(ns + "docset");
로그인 후 복사

이 접근 방식은 네임스페이스를 요소 이름을 사용하여 원하는 접두사가 있는지 확인합니다.

접두사 사용자 정의

기존 XML 구조에 맞게 접두사를 사용자 정의할 수도 있습니다.

XNamespace ns = "http://url/for/sphinx";
XElement element = new XElement("container",
    new XAttribute(XNamespace.Xmlns + "sphinx", ns),
    new XElement(ns + "docset",
        new XElement(ns + "schema"),
            new XElement(ns + "field", new XAttribute("name", "subject")),
            new XElement(ns + "field", new XAttribute("name", "content")),
            new XElement(ns + "attr",
                         new XAttribute("name", "published"),
                         new XAttribute("type", "timestamp"))));
로그인 후 복사

이 코드는 제공된 예와 유사한 XML을 생성합니다.

<container xmlns:sphinx="http://url/for/sphinx">
  <sphinx:docset>
    <sphinx:schema />
    <sphinx:field name="subject" />
    <sphinx:field name="content" />
    <sphinx:attr name="published" type="timestamp" />
  </sphinx:docset>
</container>
로그인 후 복사

위 내용은 XElement를 사용하여 XML 문서를 만들 때 네임스페이스와 접두사를 올바르게 처리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿