编辑xml文件中多个节点的相同属性

时间:2014-05-18 23:41:16

标签: c# xml wpf linq

我有一个像这样的xml文件:

<Atletas>
<Atleta Id="0" Nombre="Eduardo"/>
<Atleta Id="1" Nombre="Daniel" />
<Atleta Id="2" Nombre="Carlos" />
<Atleta Id="3" Nombre="Gabriel" />
<Atleta Id="4" Nombre="Pedro"/>
<Atleta Id="5" Nombre="Juan"/>
</Atletas>

使用此查询删除某些节点后:

       XDocument doc = XDocument.Load(spath);
        try
        {
            var resultQuery = doc.Element("Atletas")
                   .Elements("Atleta")
                   .Where(x => (int?)x.Attribute("Id") == Convert.ToInt32(dGridTest.SelectedIndex.ToString()));

            if (resultQuery != null)
            {
                resultQuery.Remove();    
            }

            doc.Save(spath);

我有这个结果:

<Atletas>
<Atleta Id="0" Nombre="Eduardo"/>
<Atleta Id="1" Nombre="Daniel" />
<Atleta Id="4" Nombre="Pedro"/>
<Atleta Id="5" Nombre="Juan"/>
</Atletas>

问题是,我如何编辑Id = 4和Id = 5的值才能拥有这个xml:

<Atletas>
<Atleta Id="0" Nombre="Eduardo"/>
<Atleta Id="1" Nombre="Daniel" />
<Atleta Id="2" Nombre="Pedro"/>
<Atleta Id="3" Nombre="Juan"/>
</Atletas>

我使用linq和wpf。

1 个答案:

答案 0 :(得分:1)

您可以获取属性(删除元素后),然后使用XAttribute.SetValue方法

var attributes = doc.Element("Atletas")
                 .Elements("Atleta")
                 .Select(x => x.Attribute("Id"));

int i = 0;
foreach(var attr in attributes)
       attr.SetValue(i++);

doc.Save(spath);