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:
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~