我有一个像这样的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。
答案 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);