xml – 具有命名空间的XPath选择节点

它的一个.vbproj,看起来像这样
<Project DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
    <PropertyGroup>
        <ProjectGuid>15a7ee82-9020-4fda-a7fb-85a61664692d</ProjectGuid>

所有我想得到的是ProjectGuid,但它不工作,当一个命名空间有…

Dim xmlDoc As New XmlDocument()
 Dim filePath As String = Path.Combine(mDirectory,name + "\" + name + ".vbproj")
 xmlDoc.Load(filePath)
 Dim value As Object = xmlDoc.SelectNodes("/Project/PropertyGroup/ProjectGuid")

我可以做什么来解决这个问题?

执行这样的事情(IMHO)的最好方法是创建一个命名空间管理器。这可以用于调用SelectNodes以指示哪些命名空间URL连接到哪些前缀。我通常设置一个静态属性,返回一个像这样的足够的实例(它是C#,你必须翻译):
private static XmlNamespaceManager _nsMgr;
public static XmlNamespaceManager NsMgr
{
  get
  {
    if (_nsMgr == null)
    {
      _nsMgr = new XmlNamespaceManager(new NaMetable());
      _nsMgr.AddNamespace("msb","http://schemas.microsoft.com/developer/msbuild/2003");
    }
    return _nsMgr;
  }
}

在这里只包含一个命名空间,但你可以有多个。然后您可以从文档中选择如下:

Dim value As Object = xmlDoc.SelectNodes("/msb:Project/msb:PropertyGroup/msb:ProjectGuid",NsMgr)

请注意,所有元素都在指定的命名空间中。

相关文章

php输出xml格式字符串
J2ME Mobile 3D入门教程系列文章之一
XML轻松学习手册
XML入门的常见问题(一)
XML入门的常见问题(三)
XML轻松学习手册(2)XML概念