c#中,如何在xml文件的指定位置插入节点?
比如如下的XML文件:<Books><Book><Title>Thefirst</Title><ISBN>111111</ISBN><Author>Mao</Author...
比如如下的XML文件:
<Books>
<Book>
<Title>The first</Title>
<ISBN>111111</ISBN>
<Author>Mao</Author>
<Price>100</Price>
<Unit>$</Unit>
</Book>
<Book>
<Title>The Third</Title>
<ISBN>333333</ISBN>
<Author>Jiang</Author>
<Price>300</Price>
<Unit>$</Unit>
</Book>
</Books>
想在这两个节点中间插入一个ISBN=“222222”的新元素(根据ISBN号来排序的):
<Book>
<Title>The Second</Title>
<ISBN>222222</ISBN>
<Author>Deng</Author>
<Price>200</Price>
<Unit>$</Unit>
</Book>
执行完插入操作之后,XML文件变为:
<Books>
<Book>
<Title>The first</Title>
<ISBN>111111</ISBN>
<Author>Mao</Author>
<Price>100</Price>
<Unit>$</Unit>
</Book>
<Book>
<Title>The Second</Title>
<ISBN>222222</ISBN>
<Author>Deng</Author>
<Price>200</Price>
<Unit>$</Unit>
</Book>
<Book>
<Title>The Third</Title>
<ISBN>333333</ISBN>
<Author>Jiang</Author>
<Price>300</Price>
<Unit>$</Unit>
</Book>
</Books>
这个该怎么实现啊,请教大神,请不吝赐教,谢谢~~ 展开
<Books>
<Book>
<Title>The first</Title>
<ISBN>111111</ISBN>
<Author>Mao</Author>
<Price>100</Price>
<Unit>$</Unit>
</Book>
<Book>
<Title>The Third</Title>
<ISBN>333333</ISBN>
<Author>Jiang</Author>
<Price>300</Price>
<Unit>$</Unit>
</Book>
</Books>
想在这两个节点中间插入一个ISBN=“222222”的新元素(根据ISBN号来排序的):
<Book>
<Title>The Second</Title>
<ISBN>222222</ISBN>
<Author>Deng</Author>
<Price>200</Price>
<Unit>$</Unit>
</Book>
执行完插入操作之后,XML文件变为:
<Books>
<Book>
<Title>The first</Title>
<ISBN>111111</ISBN>
<Author>Mao</Author>
<Price>100</Price>
<Unit>$</Unit>
</Book>
<Book>
<Title>The Second</Title>
<ISBN>222222</ISBN>
<Author>Deng</Author>
<Price>200</Price>
<Unit>$</Unit>
</Book>
<Book>
<Title>The Third</Title>
<ISBN>333333</ISBN>
<Author>Jiang</Author>
<Price>300</Price>
<Unit>$</Unit>
</Book>
</Books>
这个该怎么实现啊,请教大神,请不吝赐教,谢谢~~ 展开
1个回答
展开全部
XmlDocument doc = new XmlDocument();
doc.Load("test.xml");
XmlNode rootNode = doc.SelectSingleNode("Books");
XmlNodeList nodelist = doc.SelectNodes("Books/Book");
XmlNode flagNode = null;
foreach (XmlNode tempNode in nodelist) {
if (int.Parse(tempNode.SelectSingleNode("ISBN").InnerText) < 222222)
{
flagNode = tempNode;
}
}
XmlNode nodeA = doc.CreateElement("Book");
nodeA.InnerXml = "<Title>The Second</Title><ISBN>222222</ISBN><Author>Deng</Author><Price>200</Price><Unit>$</Unit>";
if (flagNode != null) {
rootNode.InsertAfter(nodeA,flagNode);
}
doc.Save("test.xml");
这只是提供了一个简单的思路,其实你完全封装一个方法,传进来一个封装好的XmlNode,很方便的,其实就是一个简单的排序
doc.Load("test.xml");
XmlNode rootNode = doc.SelectSingleNode("Books");
XmlNodeList nodelist = doc.SelectNodes("Books/Book");
XmlNode flagNode = null;
foreach (XmlNode tempNode in nodelist) {
if (int.Parse(tempNode.SelectSingleNode("ISBN").InnerText) < 222222)
{
flagNode = tempNode;
}
}
XmlNode nodeA = doc.CreateElement("Book");
nodeA.InnerXml = "<Title>The Second</Title><ISBN>222222</ISBN><Author>Deng</Author><Price>200</Price><Unit>$</Unit>";
if (flagNode != null) {
rootNode.InsertAfter(nodeA,flagNode);
}
doc.Save("test.xml");
这只是提供了一个简单的思路,其实你完全封装一个方法,传进来一个封装好的XmlNode,很方便的,其实就是一个简单的排序
追问
速度这么快啊,非常感谢,能实现我的要求,但如何检查是否有重复的ISBN号存在呢?若xml中已经有了重复的ISBN= 222222的元素 , 则删除原有的元素,插入新的元素,又该如何实现呢?请再指教,谢谢~
追答
上面不是有个nodelist么,循环遍历的时候判断是否已经存在,如果已经存在的话就删掉,应该没有难度吧,其实这种方法并不是推荐的,你学学linq to xml,可以像用sql一样对xml中得元素进行crud
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询