我有一个xmldocument,我正在加载xml。
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条目并相应地设置innertext。我正在使用以下代码将内部文本插入符合条件的元素:
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";
我收到错误。我能够将innertext插入到已经有值的任何元素中,但是当元素为空时我不能(例如<address2/>
)。想法?
答案 0 :(得分: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");
答案 1 :(得分:0)
检查address2 xml标记是否为空。 如果是,请转到其父级并删除标记,然后再次添加带有值的相同标记。 如果不是,请将内部文本分配给address2。
如果您需要代码,请告诉我。
答案 2 :(得分: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);
DEMO :http://ideone.com/Cf7YI