Linq2Xml - 根据子项的属性值

时间:2016-03-31 10:03:11

标签: xml linq linq-to-xml

我有一个简单的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。

1 个答案:

答案 0 :(得分:0)

尝试

var forms = root.Descendants("form")
                .Where(form => form.Elements("roles")
                                   .Elements("role")
                                   .Attributes("name")
                                   .Any(n => roles.Contains(n.Value))
                       ).ToList();