XElement 를 XmlNode 로 변환(및 XmlNode 를 XElement 로 변환){전송}
Sometimes you want to convert an XmlNode to an XElement and back again. Some programming libraries define methods that take XmlNode objects as parameters. These libraries also may contain properties and methods that return XmlNode objects. However, it is more convenient to work with LINQ to XML instead of the classes in System.Xml (XmlDocument, XmlNode, etc.) This post presents a bit of code to do these conversions.
(Update March 5, 2009 - I've written a blog post that shows how to convert from XDocument to XmlDocument (and vice versa). The code presented in that post is a superset of the code presented in this code.)
As an example of where you need these methods, you can do a lot with SharePoint using web services. The proxy classes that wsdl.exe creates contain methods that use classes in System.Xml.
It is convenient to write these conversions as extension methods. When converting to and from classes in System.Xml, the code reads much better when you tack an extension method on the end instead of surrounding the expression with a method call. The following code shows how to call the GetListItems method of the Lists web service using the GetXmlNode and GetXElement extension methods:
XElement queryOptions = new XElement("QueryOptions",
new XElement("Folder", "Open XML Documents"),
new XElement("ViewAttributes", new XAttribute("Scope", "Recursive"))
);
XElement viewFields = new XElement("ViewFields",
new XElement("FieldRef", new XAttribute("Name", "GUID")),
new XElement("FieldRef", new XAttribute("Name", "ContentType")),
new XElement("FieldRef", new XAttribute("Name", "BaseName")),
new XElement("FieldRef", new XAttribute("Name", "Modified")),
new XElement("FieldRef", new XAttribute("Name", "EncodedAbsUrl"))
);
XElement listContent = wsList
.GetListItems(documentLibraryGUID,
null, null, viewFields.GetXmlNode(),
null, queryOptions.GetXmlNode(), webId)
.GetXElement();
To create an XmlNode from an XElement, you create an XmlReader using the XNode.CreateReader method, create an XmlDocument, and load the document using the XmlReader. XmlDocument inherits XmlNode.
To create an XElement from an XmlNode, you create an XDocument, create an XmlWriter using the XContainer.CreateWriter method, write the XmlNode to the XDocument, and return the root element of the XDocument.
The following example contains the extension methods and some code that shows their use:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Xml;
using System.Xml.Linq;
public static class MyExtensions
{
public static XElement GetXElement(this XmlNode node)
{
XDocument xDoc = new XDocument();
using (XmlWriter xmlWriter = xDoc.CreateWriter())
node.WriteTo(xmlWriter);
return xDoc.Root;
}
public static XmlNode GetXmlNode(this XElement element)
{
using (XmlReader xmlReader = element.CreateReader())
{
XmlDocument xmlDoc = new XmlDocument();
xmlDoc.Load(xmlReader);
return xmlDoc;
}
}
}
class Program
{
static void Main(string[] args)
{
XElement e = new XElement("Root",
new XElement("Child",
new XAttribute("Att", "1")
)
);
XmlNode xmlNode = e.GetXmlNode();
Console.WriteLine(xmlNode.OuterXml);
XElement newElement = xmlNode.GetXElement();
Console.WriteLine(newElement);
}
}
Code is attached.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
[Spring] properties 파일에 정의된 값 가져오기실시간 강의 수업 중 Admin key에 관련된 이야기가 나와 1,2차 Python, Flask 프로젝트에서 DB등 보완이 필요한 값들에 대해서 다른 곳에 따로 저장하고 변수에는 Path 설정해주고 github에 올...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.