我试图向现有的xml节点添加一个新属性,我的xml如下所示:
<Atletas>
<Atleta Id="0" Nombre="TextBox4" Genero="Masculino" Edad="TextBox" />
<Atleta Id="1" Nombre="TextBox345" Genero="Masculino" Edad="TextBox" />
<Atleta Id="2" Nombre="Daniel1" Genero="Masculino" Edad="TextBox" />
<Atleta Id="3" Nombre="TextBox4" Genero="Masculino" Edad="TextBox" />
<Atleta Id="4" Nombre="Daniel2" Genero="Masculino" Edad="23" />
<Atleta Id="5" Nombre="Juan" Genero="Masculino" Edad="25" />
</Atletas>我希望我的xml看起来像这样:
<Atletas>
<Atleta Id="0" Nombre="Daniel" Genero="Masculino" Edad="25" Peso="89" />
<Atleta Id="1" Nombre="John" Genero="Masculino" Edad="22" />
<Atleta Id="2" Nombre="Tom" Genero="Masculino" Edad="21" Peso="78"/>
<Atleta Id="3" Nombre="Kerry" Genero="Masculino" Edad="18" />
<Atleta Id="4" Nombre="Peter" Genero="Masculino" Edad="23" Peso="76" />
<Atleta Id="5" Nombre="Juan" Genero="Masculino" Edad="25" />
</Atletas>使用linq,如何编写查询,以便使用所选节点的Id作为标识符向其添加新属性?
发布于 2014-05-20 22:17:04
使用XElement.Add方法向元素添加内容(类似属性):
var xdoc = XDocument.Load(path_to_xml);
var atleta = xdoc.Root.Elements("Atleta")
.FirstOrDefault(a => (int)a.Attribute("Id") == 3);
atleta.SetAttributeValue("Edad", 21);
atleta.Add(new XAttribute("Peso", 78));
xdoc.Save(path_to_xml);在执行此代码后,属性为Atleta的Id元素与3相同,如下所示:
<Atleta Id="3" Nombre="TextBox4" Genero="Masculino" Edad="21" Peso="78"/>建议阅读:编程指南(LINQ )。如果您有任何问题以上代码或其他您需要完成的任务,那么只需阅读本指南。
https://stackoverflow.com/questions/23770871
复制相似问题