XElement与XmlElement不可直接转换,需通过XmlDocument桥接:先用ToString()序列化XElement为字符串,再用LoadXml()加载;反向可用OuterXml解析。命名空间需关注NamespaceURI而非Prefix,性能敏感时可用XmlReader流式转换。

在C#中,XElement(来自LINQ to XML)和XmlElement(来自传统System.Xml)属于不同XML编程模型,不能直接强制转换,但可通过中间的XDocument和XmlDocument进行桥接转换。
使用XmlDocument.Load()加载XElement的XML字符串
这是最常用且可靠的方式:先将XElement序列化为字符串,再用XmlDocument加载。注意需确保XElement有根节点(单独的XElement可视为根)。
- 创建新
XmlDocument实例 - 调用
LoadXml()传入XElement.ToString() - 用
DocumentElement获取根XmlElement
示例代码:
XElement xel = new XElement("root", new XElement("child", "text"));
XmlDocument doc = new XmlDocument();
doc.LoadXml(xel.ToString());
XmlElement xmlEl = doc.DocumentElement; // 即对应的 XmlElement
处理命名空间时需注意前缀一致性
若XElement含命名空间(如xmlns="http://example.com"),XmlDocument会正确解析,但XmlElement.Prefix和XmlElement.NamespaceURI需手动检查是否匹配预期。不建议依赖Prefix值做逻辑判断,应优先用NamespaceURI。
- 避免用
ToString(SaveOptions.OmitDuplicateNamespaces)以外的方式简化输出,否则可能丢失命名空间声明 - 若需保留默认命名空间,确保
LoadXml()输入字符串包含完整的xmlns属性
反向转换:XmlElement → XElement也适用相同思路
若后续还需转回去,可用xmlEl.OuterXml构造XElement:
XElement back = XElement.Parse(xmlEl.OuterXml);
注意OuterXml包含标签自身,InnerXml只含子内容,按需选择。
性能敏感场景可考虑流式转换(较少见)
对超大XML片段且内存敏感时,可用XmlReader和XmlWriter避免字符串中间表示:
- 用
XElement.CreateReader()获取XmlReader - 新建
XmlDocument,调用Load()传入该Reader - 再取
DocumentElement
这种方式跳过字符串序列化,但代码略冗长,一般情况推荐第一种。










