本主题演示如何查找上下文节点的同级的所有属性。 只返回集合中具有特定名称的属性。
XPath 表达式为:
../Book/@id
示例
本示例首先查找 Book 元素,然后查找名为 Book 的所有同级元素,再查找名为 id 的所有属性。 结果是一个属性集合。
本示例使用下面的 XML 文档:示例 XML 文件:图书 (LINQ to XML)。
XDocument books = XDocument.Load("Books.xml");
XElement book = 
    books
    .Root
    .Element("Book");
// LINQ to XML query
IEnumerable<XAttribute> list1 =
    from el in book.Parent.Elements("Book")
    select el.Attribute("id");
// XPath expression
IEnumerable<XAttribute> list2 =
  ((IEnumerable)book.XPathEvaluate("../Book/@id")).Cast<XAttribute>();
if (list1.Count() == list2.Count() &&
        list1.Intersect(list2).Count() == list1.Count())
    Console.WriteLine("Results are identical");
else
    Console.WriteLine("Results differ");
foreach (XAttribute el in list1)
    Console.WriteLine(el);
Dim books as XDocument = XDocument.Load("Books.xml")
Dim book As XElement = books.Root.<Book>(0)
' LINQ to XML query
Dim list1 As IEnumerable(Of XAttribute) = _
    From el In book.Parent.<Book> _
    Select el.Attribute("id")
' XPath expression
Dim list2 As IEnumerable(Of XAttribute) = DirectCast(book. _
    XPathEvaluate("../Book/@id"), IEnumerable).Cast(Of XAttribute)()
If list1.Count() = list2.Count() And _
        (list1.Intersect(list2)).Count() = list1.Count() Then
    Console.WriteLine("Results are identical")
Else
    Console.WriteLine("Results differ")
End If
For Each el As XAttribute In list1
    Console.WriteLine(el)
Next
此示例产生以下输出:
Results are identical
id="bk101"
id="bk102"