假设我有一个这样的文件:
<outer>
<inner>
<nodex attr="value1">text</attr>
<nodex attr="value2">text</attr>
</inner>
</outer>
基本上我想做的是,在C#中(这里约束为.net 2.0),这个(伪代码):
foreach node
if(node eq 'nodex')
update attr to newvalue
完成后,xml文件(在磁盘上)应如下所示:
<outer>
<inner>
<nodex attr="newvalue1">text</attr>
<nodex attr="newvalue2">text</attr>
</inner>
</outer>
这两个看起来很有希望:
Setting attributes in an XML document
但目前还不清楚他们是否真的回答了我的问题。
我在此期间编写了这段代码:
这是一个更小的案例:
public static void UpdateXML()
{
XmlDocument doc = new XmlDocument();
using (XmlReader reader = XmlReader.Create("XMLFile1.xml"))
{
doc.Load(reader);
XmlNodeList list = doc.GetElementsByTagName("nodex");
foreach (XmlNode node in list)
{
node.Attributes["attr"].Value = "newvalue";
}
}
using (XmlWriter writer = XmlWriter.Create("XMLFile1.xml"))
{
doc.Save(writer);
}
}
答案 0 :(得分:2)
最快的解决方案是使用XmlTextReader / XmlTextWriter的循环。这样你就不需要在内存中加载整个xml了。
在伪代码中:
while (reader.read)
{
if (reader.Node.Name == "nodex")
......
writer.write ...
}
答案 1 :(得分:1)
以下是可以从LinqPad
运行的示例脚本var x = @"<outer>
<inner>
<nodex attr=""value1"">text</nodex>
<nodex attr=""value2"">text</nodex>
</inner>
</outer>";
XmlDocument doc = new XmlDocument();
doc.LoadXml(x);
foreach (XmlNode n in doc.SelectNodes("//nodex"))
{
n.Attributes["attr"].Value = "new" + n.Attributes["attr"].Value.ToString();
}
doc.OuterXml.Dump();
答案 2 :(得分:0)
作为起点,您可以向我们展示您尝试过的内容,您可以使用XPATH选择要修改的节点,在xpath中按属性值搜索选择节点。
找到要更新的节点后,可以根据需要使用正常分配重新分配属性值。