このトピックでは、コンテキスト ノードの兄弟が持つすべての属性を検索する方法について説明します。 コレクション内にある特定の名前の属性のみが返されます。
XPath 式を次に示します。
../Book/@id
使用例
この例では、最初に Book 要素を検索し、次に Book という名前の兄弟要素をすべて検索します。その後、id という名前の属性をすべて検索します。 結果は属性のコレクションです。
この例では、「サンプル XML ファイル : 書籍 (LINQ to XML)」の 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"