7

我有一个要加载 xml 的 xmldocument。

xml 看起来像这样:

<Table1>
  <buyer_id>0</buyer_id>
  <buyername>CompanyA</buyername>
  <address1>123 Simpsons Dr.</address1>
  <address2/>
  <city>Springfield</city>
  <state>ST</state>
  <postalcode>12345</postalcode>
  <eaddress/>
  <phone/>
  <fax/>
</Table1>

我正在循环查看每个 CompanyA 条目并相应地设置内部文本。我正在使用以下代码将内部文本插入到符合条件的元素中:

XmlDocument dom = new XmlDocument();
dom.LoadXml(xmlString);

XmlNodeList elemList = dom.GetElementByTagName("Table1");
for(int i = 0; i < elemList.Count; i++)
{
   if(dom.GetElementsByTagName("buyername").Item(i).InnerText.Contains("CompanyA")
   {
      dom.GetElementsByTagName("address1").Item(i).InnerText = "SomeInfo";
   }
}

使用上面的代码,address1(123 Simpsons Dr.) 的值将被“SomeInfo”替换。我想将“SomeInfo”插入到 address2 元素中,但是当我尝试使用时:

dom.GetElementsByTagName("address2").Item(i).InnerText = "SomeInfo";

我得到一个错误。我可以将内部文本插入到任何已经有值的元素中,但是当元素为空时(例如<address2/>)我不能。想法?

4

3 回答 3

3

使用LINQ2XML。它完全替代了其他 XML api,比如肮脏的老白痴XmlDocument

XElement doc=XElement.Load("yourXml.xml");

foreach(var elm in doc.Descendants("Table1"))
{
if(elm.Element("buyername").Value=="CompanyA")
elm.Element("address2").Value="SomeInfo";
}
doc.Save("yourXml.xml");
于 2012-10-16T15:05:19.803 回答
0

检查 address2 xml 标签是否为空。如果是,请转到其父级并删除标签,然后再次添加具有值的相同标签。如果否,则将内部文本分配给 address2。

如果您需要代码,请告诉我。

于 2012-10-16T15:07:57.693 回答
0

在 LINQ to XML 中使用SetElementValue方法:

XDocument doc = XDocument.Load(FilePath); //replace with xml file path
IEnumerable<XElement> buyersList = doc.Descendants("Table1"); //get the table node.
var ele = (from buyer in buyersList
           where buyer.Element("buyername").Value == "CompanyA"
           select buyer).SingleOrDefault(); 
ele.SetElementValue("address1", "SomeInfo");
ele.SetElementValue("address2", "SomeInfo");
doc.Save(FilePath);

演示:http: //ideone.com/Cf7YI

于 2012-10-16T15:41:48.877 回答