c#linq-to-xml、ノードでリストを取得しますか?
-
29-09-2019 - |
質問
これは、私が使用しているテストXMLです。
<categories>
<category id="1" name="Test1">
<category id="2" name="Test2">
<misc id="1"></misc>
</category>
</category>
<category id="3" name="Test3">
<misc id="2"></misc>
</category>
今、私はそれをASPX TreeViewにバインドしたいと思います。名前カテゴリを持つ要素のみが必要であり、それらの名前がTreeViewに表示されたいです。
IDと名前を簡単に入手できます:
var d = from t in data.Descendants("category")
select new { ID = t.Attribute("id").Value, Name = t.Attribute("name").Value };
しかし、どうすれば構造をツリービューに保持できますか?
これは次のようになります:
テスト1
- > test2
テスト3
解決
私があなたを正しく理解しているなら、たぶんこのようなことですか? (私はそれをテストしていません)
class Category
{
public string ID { get; set; }
public string Name { get; set; }
public IEnumerable<Category> SubCategories { get; set; }
}
IEnumerable<Category> CategoryTreeStructure(XElement e)
{
var d = from t in e.Elements("category")
select new Category()
{
ID = t.Attribute("id").Value,
Name = t.Attribute("name").Value,
SubCategories = CategoryTreeStructure(t)
};
return d;
}
と呼んでください:
var structure = CategoryTreeStructure(doc.Root);
「名前カテゴリを持っている要素のみが欲しい」 - ここであなたが何を意味するのか理解できませんか?ただし、「名前」属性を持つ要素のみを選択したい場合は、これは機能するはずです。
...
var d = from t in e.Elements("category")
where t.Attribute("name") != null
select new Category()
...
アッパー(「名前」属性部分)はあなたが望んでいたものではないことを理解していますが、私はそれをそこに残します。コードをテストしました:
XDocument doc = XDocument.Parse(@"<categories>
<category id=""1"" name=""Test1"">
<category id=""2"" name=""Test2"">
<misc id=""1""></misc>
</category>
</category>
<category id=""3"" name=""Test3"">
<misc id=""2""></misc>
</category>
</categories>");
var structure = CategoryTreeStructure(doc.Root);
他のヒント
実際、私はあなたが求めていることを正確に行うこのリンクを見つけました:)そしてそれはlinqなしであるので、私はそれが別の答えに値すると思いました。
所属していません StackOverflow