0

我正在提取 SharePoint 网站集用户的 XML 列表,然后尝试查询 InnerXml。InnerXml 看起来像这样:

<Users xmlns="http://schemas.microsoft.com/sharepoint/soap/directory/"> 
<User ID="91" Name="Jane Smith" LoginName="domain1\jsmith" />
<User ID="814" Name="Brad Jones" LoginName="domain1\bjones" />
<User ID="1252" Name="Charles Johnson" LoginName="domain2\cjohnson" />
</Users>

el即使有 ID 为 814 的用户,查询也不返回任何内容(为 null)。

XmlNode siteUsers = tempug.GetUserCollectionFromSite();
XElement root = XElement.Parse(siteUsers.InnerXml);
    IEnumerable<XElement> siteUsersElement =
        from el in root.Elements("User")
        where (string)el.Attribute("ID") == "814"
        select el;
foreach (XElement el in siteUsersElement)
Console.WriteLine("el: " + el);

root包含 InnerXml 文本,所以我认为问题与 SharePoint 无关。

4

1 回答 1

3

您没有在Elements调用中指定命名空间。幸运的是,这在 LINQ to XML 中很容易:

XNamespace ns = "http://schemas.microsoft.com/sharepoint/soap/directory/";
...
from el in root.Elements(ns + "User");

如果您知道该ID属性将始终是一个整数,我实际上会说清楚,并且当它对您没有帮助时也避免使用查询表达式:

// TODO: Find a nicer way of doing this; you shouldn't need to parse it again
XElement root = XElement.Parse(siteUsers.InnerXml);
var siteUserElements = root.Elements(ns + "User")
                           .Where(el => (int) el.Attribute("ID") == 814);

foreach (XElement el in siteUserElements)
{
    Console.WriteLine("el: " + el);
}
于 2013-07-18T16:30:47.333 回答