我需要返回一个元素列表<AssetText>.我的查询仅返回第一个AssetText.任何想法都非常感激.
var q = from c in xDoc.Descendants("Product")
where (int) c.Element("ProductView").Element("ViewId") == 44
select (string) c.Element("ProductView").Element("AssetText").Element("Text");
Run Code Online (Sandbox Code Playgroud)
<Product>
<ProductView>
<ViewId>44</ViewId>
<AssetText>
<Text>my first Asset Text</Text>
</AssetText>
<AssetText>
<Text>my second Asset Text</Text>
</AssetText>
</ProductView>
<ProductView>
<ViewId>45</ViewId>
<AssetText>
<Text>my third Asset Text</Text>
</AssetText>
</ProductView>
</Product>
Run Code Online (Sandbox Code Playgroud)
更改Element("AssetText")为Elements("AssetText")获取所有AssetText元素.请注意,您还需要更改查询的其余部分,否则它只会在第一个ProductView的ViewId为44时匹配.我建议您使用第二个"from"子句:
var q = from c in xDoc.Descendants("Product")
from view in c.Elements("ProductView")
where (int) view.Element("ViewId") == 44
from assetText in view.Elements("AssetText")
select assetText.Element("Text");
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
17073 次 |
| 最近记录: |