[英]How to select xml root node when root node has attribute?
我正在尝试使用 XPath 查询 select xml 文档的根节点的所有子节点。
我的 xml 文件如下所示:
<?xml version="1.0" encoding="UTF-8" ?>
<root>
<automotive_industry>
<automotive />
<rail_global_services />
</automotive_industry>
</root>
和
<?xml version="1.0" encoding="UTF-8" ?>
<root xmlns="http://www.my_department.my_company.com/project_name">
<automotive_industry>
<automotive />
<rail_global_services />
</automotive_industry>
</root>
C# 代码到 select 根节点如下:
XmlDocument gazetteDocument = new XmlDocument();
gazetteDocument.Load(xmlFilePath);
XmlNodeList allNodes = gazetteDocument.SelectNodes("root");
此代码工作正常,当根节点没有任何属性时,它会选择根节点的所有子节点,即它适用于第一个 xml 文件,但不适用于第二个 xml 文件,因为第二个文件具有 xmlns 属性。
当根节点具有属性时,有谁知道如何 select 根节点的所有子节点?
编辑:我发现了一个 XPath 查询: /*
此查询选择根节点,无论它是否具有任何属性。 一旦选择了根节点,我就可以遍历它的所有子节点。
尽管 XML 文档中的命名空间很好,但您需要在SelectNodes
中使用它。 将此代码用于您的第二个 XML:
XmlDocument gazetteDocument = new XmlDocument();
gazetteDocument.Load(xmlFilePath);
XmlNamespaceManager nsmgr = new XmlNamespaceManager(gazetteDocument.NameTable);
nsmgr.AddNamespace("ns", "http://www.my_department.my_company.com/project_name");
XmlNodeList allNodes = gazetteDocument.SelectNodes("ns:root", nsmgr);
更好的方法是使用XDocument
和相应的类。 他们更容易使用。
您可以使用下面的 GetElementsByTagName 方法是我的代码片段
XmlDocument gazetteDocument = new XmlDocument();
gazetteDocument.Load(xmlFilePath);
XmlNodeList allNodes = gazetteDocument.GetElementsByTagName("root");
我不知道 C# 的旧 xml 方法,但是您始终可以打开文件以读取为普通文本,然后读取到第一个节点并按照您的喜好进行解析。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.