1

假设我有一个这样的文件:

<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>

这两个看起来很有希望:

覆盖 xml 文件值

在 XML 文档中设置属性

但目前尚不清楚他们是否真的回答了我的问题。


我同时写了这段代码:

这是一个更简单的情况:

    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);
        }
    }
4

3 回答 3

2

最快的解决方案是使用带有XmlTextReader / XmlTextWriter的循环。这样您就不需要将整个 xml 加载到内存中。

在伪代码中:

while (reader.read)
{
   if (reader.Node.Name == "nodex")
       ......

   writer.write ...
}

你可以在这里查看想法

于 2011-06-20T22:35:52.040 回答
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();
于 2011-06-20T22:42:17.400 回答
0

作为起点,您可以向我们展示您尝试过的内容,您可以使用 XPATH 选择要修改的节点,在 xpath 中按属性值搜索选择节点。

找到要更新的节点后,您可以根据需要通过正常分配重新分配属性值。

于 2011-06-20T22:34:26.583 回答