0

当我尝试更新我的 XML 文档中的值时,它不会编辑现有值,而是不断插入一个带有我的新值的新节点。

如果尝试了这两种方法并获得相同的结果...

var doc = XDocument.Parse(xmlString);

XElement shippingElement = (from xml2 in doc
  .Elements("extradata").Elements("SharedCustomAppData")
  .Elements("clsNameValues").Elements("clsnamevalue")
where xml2.Element("name").Attribute("Value").Value == "SHOP_FLOOR_INSTR"
select xml2).FirstOrDefault();

shippingElement.Element("value").Attribute("Value").Value = "Changed!";

XmlDocument xmlDoc = new XmlDocument();
xmlDoc.LoadXml(oLine.ExtraData);
XmlNodeList nodes = xmlDoc.SelectNodes(
   "extradata/SharedCustomAppData/clsNameValues/clsnamevalue");

foreach (XmlNode node in nodes)
{
XmlNode nameNode = node.SelectSingleNode("name");

if (nameNode != null && nameNode.Attributes["Value"].Value == "SHOP_FLOOR_INSTR")
{
    XmlNode valueNode = node.SelectSingleNode("value");

    if (valueNode != null)
    {
        valueNode.Attributes["Value"].Value = line.SHOP_FLOOR_INSTR;
    }
}
}

我尝试更新的 XML 部分如下所示:

  <SharedCustomAppData>
   <clsNameValues>
     <clsnamevalue>
       <name Value="SHOP_FLOOR_INSTR" />
       <value Value="Current value" />
     </clsnamevalue>
   </clsNameValues>
 </SharedCustomAppData>
4

2 回答 2

0

您可以对 Linq to Xml使用System.Xml.XPath扩展(我相信代码会看起来更短):

var expression = "//extradata/SharedCustomAppData/clsNameValues/clsnamevalue[name/@Value='SHOP_FLOOR_INSTR']/value";
XElement valueElement = xdoc.XPathSelectElement(expression);
if (valueElement != null)
    valueElement.SetAttributeValue("Value", "Changed!");

还要小心命名空间(如果在父节点上声明了一些命名空间,则从您的示例 xml 中不清楚)。

于 2013-01-25T00:39:07.010 回答
0

赋值语句中的元素名称不应该是“名称”而不是“值”吗?

尝试这个:

var doc = XDocument.Parse(xmlString);

XElement shippingElement = (from xml2 in doc
   .Elements("extradata").Elements("SharedCustomAppData")
   .Elements("clsNameValues").Elements("clsnamevalue")
where xml2.Element("name").Attribute("Value").Value == "SHOP_FLOOR_INSTR"
select xml2).FirstOrDefault();

shippingElement.Element("name").Attribute("Value").Value = "Changed!";
于 2013-01-25T00:14:31.007 回答