我有一个简单的xml:
<forms for="ApplicationTestSettings">
<form name="Parameter12Settings" title="Parameter12 Settings" url="/Parameter12Settings">
<roles>
<role name="Parameter12-Reader" />
<role name="Parameter12-Writer" can-add="1" can-edit="1" can-delete="0" />
</roles>
</form>
<form name="Parameter34Settings" title="Parameter 34 Settings" url="/Parameter34Settings">
<roles>
<role name="Parameter34-Reader" />
<role name="Parameter34-Writer" can-add="1" can-edit="1" can-delete="0" />
</roles>
</form>
</forms>
我需要一个基于角色元素属性值的表单集合。我有一个清单:
List<string> roles = new List<string>();
roles.Add("Parameter12-Reader");
roles.Add("Parameter34-Writer");
我尝试使用此查询获取项目:
var forms = root.Descendants("form")
.Where(form => roles.Contains(form.Element("roles")
.Element("role")
.Attribute("name").Value)).ToList();
不幸的是,此查询仅分析所有表单/角色块中的第一个角色。任何人都可以告诉我,如何定义此查询以获取所有表单元素,其中role列表包含xml角色名称?
谢谢, d。
答案 0 :(得分:0)
尝试
var forms = root.Descendants("form")
.Where(form => form.Elements("roles")
.Elements("role")
.Attributes("name")
.Any(n => roles.Contains(n.Value))
).ToList();